# **MCUXpresso SDK API Reference Manual**

# **NXP Semiconductors**

Document Number: MCUXSDKIMX8MQAPIRM

Rev. 0

Dec 2018



# **Contents**

| Chapter | Introduction                        |    |
|---------|-------------------------------------|----|
| Chapter | Driver errors status                |    |
| Chapter | Architectural Overview              |    |
| Chapter | Trademarks                          |    |
| Chapter | Clock Driver                        |    |
| 5.1     | Overview                            | 1  |
| 5.2     | Data Structure Documentation        | 23 |
| 5.2.1   | struct osc_config_t                 | 23 |
| 5.2.2   | struct ccm_analog_frac_pll_config_t | 24 |
| 5.2.3   | struct ccm_analog_sscg_pll_config_t | 24 |
| 5.3     | Macro Definition Documentation      | 25 |
| 5.3.1   | FSL_CLOCK_DRIVER_VERSION            | 25 |
| 5.3.2   | ECSPI_CLOCKS                        | 25 |
| 5.3.3   | GPIO_CLOCKS                         | 25 |
| 5.3.4   | GPT_CLOCKS                          | 25 |
| 5.3.5   | I2C_CLOCKS                          | 25 |
| 5.3.6   | IOMUX_CLOCKS                        | 26 |
| 5.3.7   | PWM_CLOCKS                          | 26 |
| 5.3.8   | RDC_CLOCKS                          |    |
| 5.3.9   | SAI_CLOCKS                          | 26 |
| 5.3.10  | RDC_SEMA42_CLOCKS                   | 26 |
| 5.3.11  | UART_CLOCKS                         | 27 |
| 5.3.12  | USDHC_CLOCKS                        | 27 |
| 5.3.13  | WDOG_CLOCKS                         | 27 |
| 5.3.14  | TMU_CLOCKS                          | 27 |
| 5.3.15  | SDMA_CLOCKS                         | 27 |
| 5.3.16  | MU_CLOCKS                           | 28 |
| 5.3.17  | QSPI_CLOCKS                         | 28 |
| 5.3.18  | kCLOCK_CoreSysClk                   | 28 |
| 5.3.19  | CLOCK_GetCoreSysClkFreq             | 28 |

| <b>Section</b> Contents |                                |                |  |  |
|-------------------------|--------------------------------|----------------|--|--|
| Number                  | Title                          | Page<br>Number |  |  |
| 5.4                     | Enumeration Type Documentation | 28             |  |  |
| 5.4.1                   | clock_name_t                   |                |  |  |
| 5.4.2                   | clock_ip_name_t                |                |  |  |
| 5.4.3                   | clock_root_control_t           |                |  |  |
| 5.4.4                   | clock_rootmux_m4_clk_sel_t     |                |  |  |
| 5.4.5                   | clock_rootmux_axi_clk_sel_t    |                |  |  |
| 5.4.6                   | clock_rootmux_ahb_clk_sel_t    |                |  |  |
| 5.4.7                   | clock_rootmux_qspi_clk_sel_t   |                |  |  |
| 5.4.8                   | clock_rootmux_ecspi_clk_sel_t  |                |  |  |
| 5.4.9                   | clock_rootmux_i2c_clk_sel_t    |                |  |  |
| 5.4.10                  | clock_rootmux_uart_clk_sel_t   |                |  |  |
| 5.4.11                  | clock_rootmux_gpt_t            |                |  |  |
| 5.4.12                  | clock_rootmux_wdog_clk_sel_t   |                |  |  |
| 5.4.13                  | clock_rootmux_Pwm_clk_sel_t    |                |  |  |
| 5.4.14                  | clock_rootmux_sai_clk_sel_t    |                |  |  |
| 5.4.15                  | clock_rootmux_noc_clk_sel_t    |                |  |  |
| 5.4.16                  | clock_pll_gate_t               |                |  |  |
| 5.4.17                  | clock_gate_value_t             |                |  |  |
| 5.4.18                  | clock_pll_bypass_ctrl_t        |                |  |  |
| 5.4.19                  | clock_pll_clke_t               |                |  |  |
| 5.4.20                  | _osc_mode                      |                |  |  |
| 5.4.21                  | osc32_src_t                    |                |  |  |
| 5.4.22                  | _ccm_analog_pll_ref_clk        |                |  |  |
| 5.5                     | Function Documentation         | 38             |  |  |
| 5.5.1                   | CLOCK_SetRootMux               | 38             |  |  |
| 5.5.2                   | CLOCK_GetRootMux               | 38             |  |  |
| 5.5.3                   | CLOCK_EnableRoot               |                |  |  |
| 5.5.4                   | CLOCK_DisableRoot              |                |  |  |
| 5.5.5                   | CLOCK_IsRootEnabled            |                |  |  |
| 5.5.6                   | CLOCK_UpdateRoot               | 39             |  |  |
| 5.5.7                   | CLOCK_SetRootDivider           | 40             |  |  |
| 5.5.8                   | CLOCK_GetRootPreDivider        | 40             |  |  |
| 5.5.9                   | CLOCK_GetRootPostDivider       | 40             |  |  |
| 5.5.10                  | CLOCK_InitOSC25M               | 41             |  |  |
| 5.5.11                  | CLOCK_DeinitOSC25M             | 41             |  |  |
| 5.5.12                  | CLOCK_InitOSC27M               | 41             |  |  |
| 5.5.13                  | CLOCK_DeinitOSC27M             | 41             |  |  |
| 5.5.14                  | CLOCK_SwitchOSC32Src           | 41             |  |  |
| 5.5.15                  | CLOCK_ControlGate              | 41             |  |  |
| 5.5.16                  | CLOCK_EnableClock              |                |  |  |
| 5.5.17                  | CLOCK_DisableClock             |                |  |  |
| 5.5.18                  | CLOCK_PowerUpPll               | 42             |  |  |
| 5.5.19                  | CLOCK_PowerDownPll             |                |  |  |
| 5.5.20                  | CLOCK_SetPllBypass             | 43             |  |  |
|                         |                                |                |  |  |

| Section | Contents                                  | Pag   |
|---------|-------------------------------------------|-------|
| Number  | Title                                     | Numbe |
| 5.5.21  | CLOCK_IsPllBypassed                       | 4     |
| 5.5.22  | CLOCK_IsPIILocked                         | 4     |
| 5.5.23  | CLOCK_EnableAnalogClock                   | 4     |
| 5.5.24  | CLOCK_DisableAnalogClock                  | 4     |
| 5.5.25  | CLOCK_OverrideAnalogClke                  | 4     |
| 5.5.26  | CLOCK_OverridePllPd                       | 4     |
| 5.5.27  | CLOCK_InitArmPll                          | 4     |
| 5.5.28  | CLOCK_InitSysPll1                         | 4     |
| 5.5.29  | CLOCK_InitSysPll2                         | 4     |
| 5.5.30  | CLOCK_InitSysPll3                         | 4     |
| 5.5.31  | CLOCK_InitDramPll                         | 4     |
| 5.5.32  | CLOCK_InitAudioPll1                       | 4     |
| 5.5.33  | CLOCK_InitAudioPll2                       | 4     |
| 5.5.34  | CLOCK_InitVideoPll1                       | 4     |
| 5.5.35  | CLOCK_InitVideoPll2                       | 4     |
| 5.5.36  | CLOCK_InitSSCGPIl                         | 4     |
| 5.5.37  | CLOCK_GetSSCGPllFreq                      | 4     |
| 5.5.38  | CLOCK_InitFracPll                         |       |
| 5.5.39  | CLOCK_GetFracPllFreq                      | 4     |
| 5.5.40  | CLOCK_GetPllFreq                          |       |
| 5.5.41  | CLOCK_GetPllRefClkFreq                    |       |
| 5.5.42  | CLOCK_GetFreq                             |       |
| 5.5.43  | CLOCK_GetCoreM4Freq                       |       |
| 5.5.44  | CLOCK_GetAxiFreq                          | 5     |
| 5.5.45  | CLOCK_GetAhbFreq                          |       |
| Chapter | ECSPI: Serial Peripheral Interface Driver |       |
| 6.1     | Overview                                  | 5     |
| 6.2     | ECSPI Driver                              | 5     |
| 6.2.1   | Overview                                  | 5     |
| 6.2.2   | Typical use case                          | 5     |
| 6.2.3   | Data Structure Documentation              | 5     |
| 6.2.4   | Macro Definition Documentation            | 6     |
| 6.2.5   | Enumeration Type Documentation            |       |
| 6.2.6   | Function Documentation                    |       |
| 6.3     | ECSPI FreeRTOS Driver                     | 7     |
| 6.3.1   | Overview                                  | 7     |
| 6.3.2   | Macro Definition Documentation            | 7     |
| 6.3.3   | Function Documentation                    | 7     |

| <b>Content</b> | C |
|----------------|---|
| Content        | 5 |

| <b>Number</b>                        | Title                          | Page<br>Number |
|--------------------------------------|--------------------------------|----------------|
| Chapter                              | GPT: General Purpose Timer     |                |
| 7.1                                  | Overview                       | 79             |
| <b>7.2</b> 7.2.1                     | Function groups                |                |
| <b>7.3</b> 7.3.1                     | Typical use case               |                |
| <b>7.4</b> 7.4.1                     | Data Structure Documentation   |                |
| <b>7.5</b> 7.5.1 7.5.2               | Enumeration Type Documentation | 83             |
| 7.5.3<br>7.5.4<br>7.5.5<br>7.5.6     | gpt_input_operation_mode_t     | 84<br>84       |
| 7.5.7<br><b>7.6</b>                  | gpt_status_flag_t              | 85             |
| 7.6.1<br>7.6.2<br>7.6.3              | GPT_Init                       | 85<br>85       |
| 7.6.4<br>7.6.5<br>7.6.6              | GPT_SoftwareReset              | 86<br>86       |
| 7.6.7<br>7.6.8<br>7.6.9              | GPT_SetClockDivider            | 87<br>87       |
| 7.6.10<br>7.6.11<br>7.6.12           | GPT_GetOscClockDivider         | 87<br>88       |
| 7.6.13<br>7.6.14<br>7.6.15           | GPT_GetCurrentTimerCount       | 88<br>88       |
| 7.6.16<br>7.6.17<br>7.6.18<br>7.6.19 | GPT_GetInputCaptureValue       | 89<br>90       |
| 7.6.20<br>7.6.21<br>7.6.22           | GPT_SetOutputCompare Value     | 90<br>91       |
| 7.6.23                               | GPT_DisableInterrupts          |                |

| Section | Contents                                  | Pag   |
|---------|-------------------------------------------|-------|
| Number  | Title                                     | Numbe |
| 7.6.24  | GPT_GetEnabledInterrupts                  | 9     |
| 7.6.25  | GPT_GetStatusFlags                        | 9     |
| 7.6.26  | GPT_ClearStatusFlags                      | 9     |
| Chapter | GPIO: General-Purpose Input/Output Driver |       |
| 8.1     | Overview                                  | 9     |
| 8.2     | GPIO Driver                               | 9     |
| 8.2.1   | Overview                                  | 9     |
| 8.2.2   | Typical use case                          | 9     |
| 8.2.3   | Data Structure Documentation              | 9     |
| 8.2.4   | Macro Definition Documentation            | 9     |
| 8.2.5   | Enumeration Type Documentation            | 9     |
| 8.2.6   | Function Documentation                    | 9     |
| Chapter | I2C: Inter-Integrated Circuit Driver      |       |
| 9.1     | Overview                                  | 10    |
| 9.2     | I2C Driver                                | 10    |
| 9.2.1   | Overview                                  | 10    |
| 9.2.2   | Typical use case                          | 10    |
| 9.2.3   | Data Structure Documentation              | 10    |
| 9.2.4   | Macro Definition Documentation            | 11    |
| 9.2.5   | Typedef Documentation                     | 11    |
| 9.2.6   | Enumeration Type Documentation            | 11    |
| 9.2.7   | Function Documentation                    | 11    |
| 9.3     | I2C FreeRTOS Driver                       | 12    |
| 9.3.1   | Overview                                  | 12    |
| 9.3.2   | Macro Definition Documentation            | 12    |
| 9.3.3   | Function Documentation                    | 12    |
| Chapter | PWM: Pulse Width Modulation Driver        |       |
| 10.1    | Overview                                  | 13    |
| 10.2    | PWM Driver                                | 13    |
| 10.2.1  | Overview                                  | 13    |
| 10.2.2  | Typical use case                          |       |
| 10.2.3  | Enumeration Type Documentation            |       |
| 10.2.4  | Function Documentation                    |       |

MCUXpresso SDK API Reference Manual

| G                 | Contents                                                 | D              |
|-------------------|----------------------------------------------------------|----------------|
| Section<br>Number | Title                                                    | Page<br>Number |
| Chapter           | UART: Universal Asynchronous Receiver/Transmitter Driver |                |
| 11.1              | Overview                                                 | 143            |
| 11.2              | UART Driver                                              | 144            |
| 11.2.1            | Overview                                                 | 144            |
| 11.2.2            | Typical use case                                         | 144            |
| 11.2.3            | Data Structure Documentation                             | 151            |
| 11.2.4            | Macro Definition Documentation                           | 153            |
| 11.2.5            | Typedef Documentation                                    | 153            |
| 11.2.6            | Enumeration Type Documentation                           | 153            |
| 11.2.7            | Function Documentation                                   | 155            |
| 11.2.8            | Variable Documentation                                   | 171            |
| 11.3              | UART FreeRTOS Driver                                     | 172            |
| 11.3.1            | Overview                                                 | 172            |
| 11.3.2            | Data Structure Documentation                             | 172            |
| 11.3.3            | Macro Definition Documentation                           | 173            |
| 11.3.4            | Function Documentation                                   | 173            |
| Chapter           | MU: Messaging Unit                                       |                |
| 12.1              | Overview                                                 | 175            |
| 12.2              | Function description                                     | 175            |
| 12.2.1            | MU initialization                                        | 175            |
| 12.2.2            | MU message                                               | 175            |
| 12.2.3            | MU flags                                                 |                |
| 12.2.4            | Status and interrupt                                     | 176            |
| 12.2.5            | MU misc functions                                        |                |
| 12.3              | Macro Definition Documentation                           | 179            |
| 12.3.1            | FSL_MU_DRIVER_VERSION                                    | 179            |

12.4

12.4.1

12.4.2

12.4.3

12.5

12.5.1

12.5.2

12.5.3

12.5.4

12.5.5

12.5.6

| Section | Contents                                      | Page   |
|---------|-----------------------------------------------|--------|
| Number  | Title                                         | Number |
| 12.5.7  | MU_SetFlagsNonBlocking                        | 182    |
| 12.5.8  | MU_SetFlags                                   |        |
| 12.5.9  | MU_GetFlags                                   |        |
| 12.5.10 | MU_GetStatusFlags                             |        |
| 12.5.11 | MU_ClearStatusFlags                           |        |
| 12.5.12 | MU_EnableInterrupts                           |        |
| 12.5.13 | MU_DisableInterrupts                          |        |
| 12.5.14 | MU_TriggerInterrupts                          |        |
| 12.5.15 | MU_ClearNmi                                   |        |
| 12.5.16 | MU_BootCoreB                                  |        |
| 12.5.17 | MU_HoldCoreBReset                             |        |
| 12.5.18 | MU_BootOtherCore                              |        |
| 12.5.19 | MU_HoldOtherCoreReset                         |        |
| 12.5.20 | MU_ResetBothSides                             |        |
| 12.5.21 | MU_HardwareResetOtherCore                     |        |
| 12.5.22 | MU_SetClockOnOtherCoreEnable                  |        |
| 12.5.23 | MU_GetOtherCorePowerMode                      |        |
|         |                                               |        |
| Chapter | QSPI: Quad Serial Peripheral Interface Driver |        |
| 13.1    | Overview                                      | 191    |
| 13.2    | Data Structure Documentation                  | 195    |
| 13.2.1  | struct qspi_dqs_config_t                      |        |
| 13.2.2  | struct qspi_flash_timing_t                    |        |
| 13.2.3  | struct qspi_config_t                          |        |
| 13.2.4  | struct qspi_flash_config_t                    |        |
| 13.2.5  | struct qspi_transfer_t                        |        |
| 13.2.3  | Struct qspi_transfer_t                        | 170    |
| 13.3    | Macro Definition Documentation                | 198    |
| 13.3.1  | FSL_QSPI_DRIVER_VERSION                       | 198    |
| 13.4    | Enumeration Type Documentation                | 198    |
| 13.4.1  | _status_t                                     | 198    |
| 13.4.2  | qspi_read_area_t                              |        |
| 13.4.3  | qspi_command_seq_t                            |        |
| 13.4.4  | qspi_fifo_t                                   |        |
| 13.4.5  | qspi_endianness_t                             |        |
| 13.4.6  | _qspi_error_flags                             |        |
| 13.4.7  | _qspi_flags                                   |        |
| 13.4.8  | _qspi_interrupt_enable                        |        |
| 13.4.9  | _qspi_dma_enable                              |        |
| 13.4.10 | qspi_dqs_phrase_shift_t                       |        |
| 13.5    | Function Documentation                        |        |

MCUXpresso SDK API Reference Manual NXP Semiconductors

| Section Contents Pag |                                   |                |  |  |
|----------------------|-----------------------------------|----------------|--|--|
| Number               | Title                             | Page<br>Number |  |  |
| Tullibei             |                                   | Mannoci        |  |  |
| 13.5.1               | QSPI_GetInstance                  | 201            |  |  |
| 13.5.2               | QSPI_Init                         | 201            |  |  |
| 13.5.3               | QSPI_GetDefaultQspiConfig         | 201            |  |  |
| 13.5.4               | QSPI_Deinit                       | 202            |  |  |
| 13.5.5               | QSPI_SetFlashConfig               |                |  |  |
| 13.5.6               | QSPI_SoftwareReset                |                |  |  |
| 13.5.7               | QSPI_Enable                       |                |  |  |
| 13.5.8               | QSPI_GetStatusFlags               |                |  |  |
| 13.5.9               | QSPI_GetErrorStatusFlags          |                |  |  |
| 13.5.10              | QSPI_ClearErrorFlag               |                |  |  |
| 13.5.11              | QSPI_EnableInterrupts             |                |  |  |
| 13.5.12              | QSPI_DisableInterrupts            |                |  |  |
| 13.5.13              | QSPI_EnableDMA                    |                |  |  |
| 13.5.14              | QSPI_GetTxDataRegisterAddress     |                |  |  |
| 13.5.15              | QSPI_GetRxDataRegisterAddress     |                |  |  |
| 13.5.16              | QSPI_SetIPCommandAddress          |                |  |  |
| 13.5.17              | QSPI_SetIPCommandSize             |                |  |  |
| 13.5.17              | QSPI_ExecuteIPCommand             |                |  |  |
| 13.5.19              | QSPI_ExecuteAHBCommand            |                |  |  |
| 13.5.19              | QSPI_EnableIPParallelMode         |                |  |  |
| 13.5.21              | QSPI_EnableAHBParallelMode        |                |  |  |
| 13.5.21              | QSPI_UpdateLUT                    |                |  |  |
| 13.5.22              |                                   |                |  |  |
| 13.5.24              | QSPI_ClearFifo                    |                |  |  |
|                      | QSPI_ClearCommandSequence         |                |  |  |
| 13.5.25              | QSPI_EnableDDRMode                |                |  |  |
| 13.5.26              | QSPI_SetReadDataArea              |                |  |  |
| 13.5.27              | QSPI_WriteBlocking                |                |  |  |
| 13.5.28              | QSPI_WriteData                    |                |  |  |
| 13.5.29              | QSPI_ReadBlocking                 |                |  |  |
| 13.5.30              | QSPI_ReadData                     |                |  |  |
| 13.5.31              | QSPI_TransferSendBlocking         |                |  |  |
| 13.5.32              | QSPI_TransferReceiveBlocking      | 210            |  |  |
|                      |                                   |                |  |  |
| Chapter              | RDC: Resource Domain Controller   |                |  |  |
| 14.1                 | Overview                          | 211            |  |  |
|                      |                                   |                |  |  |
| 14.2                 | Data Structure Documentation      | 213            |  |  |
| 14.2.1               | struct rdc_hardware_config_t      | 213            |  |  |
| 14.2.2               | struct rdc_domain_assignment_t    | 213            |  |  |
| 14.2.3               | struct rdc_periph_access_config_t |                |  |  |
| 14.2.4               | struct rdc_mem_access_config_t    |                |  |  |
| 14.2.5               | struct rdc_mem_status_t           |                |  |  |
|                      |                                   |                |  |  |
| 14.3                 | Macro Definition Documentation    | 215            |  |  |
|                      |                                   |                |  |  |

| Section | Contents                               | Page   |
|---------|----------------------------------------|--------|
| Number  | Title                                  | Number |
| 14.3.1  | FSL_RDC_DRIVER_VERSION                 | 215    |
| 14.4    | Enumeration Type Documentation         | 215    |
| 14.4.1  | _rdc_interrupts                        | 215    |
| 14.4.2  | _rdc_flags                             | 216    |
| 14.4.3  | _rdc_access_policy                     | 216    |
| 14.5    | Function Documentation                 | 216    |
| 14.5.1  | RDC_Init                               | 216    |
| 14.5.2  | RDC_Deinit                             | 216    |
| 14.5.3  | RDC_GetHardwareConfig                  | 216    |
| 14.5.4  | RDC_EnableInterrupts                   | 217    |
| 14.5.5  | RDC_DisableInterrupts                  | 217    |
| 14.5.6  | RDC_GetInterruptStatus                 |        |
| 14.5.7  | RDC_ClearInterruptStatus               |        |
| 14.5.8  | RDC_GetStatus                          |        |
| 14.5.9  | RDC_ClearStatus                        |        |
| 14.5.10 | RDC_SetMasterDomainAssignment          |        |
| 14.5.11 | RDC_GetDefaultMasterDomainAssignment   |        |
| 14.5.12 | RDC_LockMasterDomainAssignment         |        |
| 14.5.13 | RDC_SetPeriphAccessConfig              |        |
| 14.5.14 | RDC_GetDefaultPeriphAccessConfig       |        |
| 14.5.15 | RDC_LockPeriphAccessConfig             |        |
| 14.5.16 | RDC_SetMemAccessConfig                 |        |
| 14.5.17 | RDC_GetDefaultMemAccessConfig          |        |
| 14.5.18 | RDC_LockMemAccessConfig                |        |
| 14.5.19 | RDC_SetMemAccessValid                  |        |
| 14.5.20 | RDC_GetMemViolationStatus              |        |
| 14.5.21 | RDC_ClearMemViolationFlag              |        |
| 14.5.22 | RDC GetCurrentMasterDomainId           |        |
| 14.3.22 | RDC_GeteurentwasterDomainid            | 222    |
| Chapter | RDC_SEMA42: Hardware Semaphores Driver |        |
| 15.1    | Overview                               | 223    |
| 15.2    | Macro Definition Documentation         | 224    |
| 15.2.1  | RDC_SEMA42_GATE_NUM_RESET_ALL          |        |
| 15.2.2  | RDC_SEMA42_GATEn                       |        |
| 15.2.3  | RDC_SEMA42_GATE_COUNT                  |        |
| 15.3    | Function Documentation                 | 224    |
| 15.3.1  | RDC_SEMA42_Init                        |        |
| 15.3.2  | RDC_SEMA42_Deinit                      |        |
| 15.3.3  | RDC_SEMA42_TryLock                     |        |

MCUXpresso SDK API Reference Manual

15.3.4

| Number         Title         Number           15.3.5         RDC_SEMA42_Unlock         226           15.3.6         RDC_SEMA42_GetLockMasterIndex         226           15.3.7         RDC_SEMA42_GetLockDomainID         226           15.3.8         RDC_SEMA42_ResetGate         227           15.3.9         RDC_SEMA42_ResetAllGates         228           Chapter SAI: Serial Audio Interface           16.1         Overview         229           16.2         Typical use case         229           16.2.1         SAI Send/receive using an interrupt method         229           16.2.2         SAI Send/receive using a DMA method         229           16.3         Data Structure Documentation         236           16.3.1         struct sai_transfer_format_t         236           16.3.2         struct sai_transfer_format_t         236           16.3.3         struct sai_transfer_format_t         237           16.4.1         Macro Definition Documentation         238           16.4.2         Macro Definition Documentation         238           16.5.1         _sai_channel_mask         238           16.5.2         _sai_channel_mask         238           16.5.3         sa                                                | Section | Contents                                   | Page   |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--------------------------------------------|--------|
| 15.3.6     RDC_SEMA42_GetLockDonainID     226       15.3.7     RDC_SEMA42_GetLockDonainID     227       15.3.8     RDC_SEMA42_ResetGate     227       15.3.9     RDC_SEMA42_ResetGate     228       Chapter SAI: Serial Audio Interface       16.1     Overview     229       16.2     Typical use case     229       16.2.1     SAI Send/receive using an interrupt method     229       16.2.2     SAI Send/receive using a DMA method     229       16.3     Data Structure Documentation     236       16.3.1     struct sai_config_t     236       16.3.2     struct sai_transfer_format_t     236       16.3.3     struct sai_transfer_t     237       16.3.4     struct_sai_handle     237       16.3.5     struct_sai_handle     237       16.4     Macro Definition Documentation     238       16.4.1     SAI_XFER_QUEUE_SIZE     238       16.5.2     _sai_channel_mask     238       16.5.3     sai_protocol_t     238       16.5.5     sai_data_order_t     239       16.5.6     sai_data_order_t     239       16.5.7     sai_data_order_t     239       16.5.8     sai_sync_mode_t     239       16.5.9     sai_mate_sl                                                                                                                              | Number  | Title                                      | Number |
| 15.3.7     RDC_SEMA42_GetLockDomainID     226       15.3.8     RDC_SEMA42_ResetGate     227       15.3.9     RDC_SEMA42_ResetAllGates     228       Chapter SAI: Serial Audio Interface       16.1     Overview     229       16.2     Typical use case     229       16.2.1     SAI Send/receive using an interrupt method     229       16.2.2     SAI Send/receive using a DMA method     229       16.3     Data Structure Documentation     236       16.3.1     struct sai_config_t     236       16.3.2     struct sai_transfer_ormat_t     236       16.3.3     struct sai_transfer_t     237       16.3.4     struct_sai_transfer_t     237       16.4.1     Macro Definition Documentation     238       16.4.1     SAI_XFER_QUEUE_SIZE     238       16.5.1     _sai_status_t     238       16.5.2     _sai_channel_mask     238       16.5.3     sai_mono_sterco_t     239       16.5.4     sai_master_slave_t     239       16.5.5     sai_dock_polarity_t     239       16.5.6     sai_data_order_t     239       16.5.7     sai_clock_polarity_t     239       16.5.8     sai_syne_mode_t     239       16.5.10     sai_male_nanle_                                                                                                                  | 15.3.5  | RDC_SEMA42_Unlock                          | 226    |
| 15.3.8     RDC_SEMA42_ResetGate     227       15.3.9     RDC_SEMA42_ResetAllGates     228       Chapter SAI: Serial Audio Interface       16.1     Overview     229       16.2     Typical use case     229       16.2.1     SAI Send/receive using an interrupt method     229       16.2.2     SAI Send/receive using a DMA method     229       16.3     Data Structure Documentation     236       16.3.1     struct sai_config_t     236       16.3.2     struct sai_transfer_format_t     236       16.3.3     struct sai_transfer_t     237       16.3.4     struct_sai_handle     237       16.4     Macro Definition Documentation     238       16.4.1     SAI_XFER_QUEUE_SIZE     238       16.5.2     sai_status_t     238       16.5.3     sai_protocol_t     238       16.5.4     sai_master_slave_t     238       16.5.5     sai_master_slave_t     239       16.5.6     sai_data_order_t     239       16.5.7     sai_clock_polarity_t     239       16.5.8     sai_syne_mode_t     239       16.5.9     sai_malk_source_t     240       16.5.11     _sai_interrupt_enable_t     240       16.5.12     _sai_dma_enable_t                                                                                                                            | 15.3.6  | RDC_SEMA42_GetLockMasterIndex              | 226    |
| 15.3.9   RDC_SEMA42_ResetAllGates   228                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 15.3.7  | RDC_SEMA42_GetLockDomainID                 | 226    |
| Chapter         SAI: Serial Audio Interface           16.1         Overview         229           16.2         Typical use case         229           16.2.1         SAI Send/receive using an interrupt method         229           16.2.2         SAI Send/receive using a DMA method         229           16.3         Data Structure Documentation         236           16.3.1         struct sai_config_t         236           16.3.2         struct sai_transfer_format_t         236           16.3.3         struct sai_transfer_t         237           16.3.4         struct_sai_handle         237           16.3.4         struct_sai_handle         237           16.4.1         SAI_XFER_QUEUE_SIZE         238           16.5.5         Enumeration Type Documentation         238           16.5.1         _sai_status_t         238           16.5.2         _sai_channel_mask         238           16.5.3         sai_protocol_t         238           16.5.4         sai_master_slave_t         239           16.5.5         sai_mono_stereo_t         239           16.5.6         sai_data_order_t         239           16.5.7         sai_clock_polarity_t         239                                                                  | 15.3.8  | RDC_SEMA42_ResetGate                       | 227    |
| 16.1       Overview       229         16.2       Typical use case       229         16.2.1       SAI Send/receive using an interrupt method       229         16.2.2       SAI Send/receive using a DMA method       229         16.3       Data Structure Documentation       236         16.3.1       struct sai_transfer_format_t       236         16.3.2       struct sai_transfer_format_t       236         16.3.3       struct sai_transfer_t       237         16.4       Macro Definition Documentation       238         16.4.1       SAI_XFER_QUEUE_SIZE       238         16.5.2       sai_status_t       238         16.5.3       sai_channel_mask       238         16.5.4       sai_master_slave_t       239         16.5.5       sai_mono_sterce_t       239         16.5.6       sai_master_slave_t       239         16.5.7       sai_clock_polarity_t       239         16.5.8       sai_stync_mode_t       239         16.5.9       sai_mclk_source_t       240         16.5.10       sai_bck_source_t       240         16.5.12       sai_dma_enable_t       240         16.5.13       sai_siflags       241                                                                                                                                  | 15.3.9  | RDC_SEMA42_ResetAllGates                   | 228    |
| 16.2         Typical use case         229           16.2.1         SAI Send/receive using an interrupt method         229           16.2.2         SAI Send/receive using a DMA method         229           16.3         Data Structure Documentation         236           16.3.1         struct sai_config_t         236           16.3.2         struct sai_transfer_format_t         236           16.3.3         struct sai_transfer_t         237           16.3.4         struct_sai_handle         237           16.4         Macro Definition Documentation         238           16.4.1         SAI_XFER_QUEUE_SIZE         238           16.5.2         _sai_status_t         238           16.5.3         _sai_tstatus_t         238           16.5.4         _sai_status_t         238           16.5.5         _sai_monol_mask         238           16.5.6         _sai_protocol_t         238           16.5.5         sai_mono_stereo_t         239           16.5.5         sai_mono_stereo_t         239           16.5.6         sai_data_order_t         239           16.5.7         sai_clock_polarity_t         239           16.5.9         sai_mclk_source_t         240 <td>Chapter</td> <td>SAI: Serial Audio Interface</td> <td></td> | Chapter | SAI: Serial Audio Interface                |        |
| 16.2.1       SAI Send/receive using an interrupt method       229         16.2.2       SAI Send/receive using a DMA method       229         16.3       Data Structure Documentation       236         16.3.1       struct sai_config_t       236         16.3.2       struct sai_transfer_format_t       236         16.3.3       struct sai_transfer_t       237         16.3.4       struct_sai_handle       237         16.4       Macro Definition Documentation       238         16.4.1       SAI_XFER_QUEUE_SIZE       238         16.5       Enumeration Type Documentation       238         16.5.1       _sai_status_t       238         16.5.2       _sai_channel_mask       238         16.5.3       sai_protocol_t       238         16.5.4       sai_master_slave_t       239         16.5.5       sai_master_slave_t       239         16.5.5       sai_mono_stereo_t       239         16.5.6       sai_data_order_t       239         16.5.7       sai_clock_polarity_t       239         16.5.8       sai_sayne_mode_t       239         16.5.9       sai_mick_source_t       240         16.5.10       sai_bclk_source_t       240                                                                                                              | 16.1    | Overview                                   | 229    |
| 16.2.2       SAI Send/receive using a DMA method       229         16.3       Data Structure Documentation       236         16.3.1       struct sai_config_t       236         16.3.2       struct sai_transfer_format_t       236         16.3.3       struct sai_transfer_t       237         16.3.4       struct_sai_handle       237         16.4       Macro Definition Documentation       238         16.5.1       SAI_XFER_QUEUE_SIZE       238         16.5.2       _sai_status_t       238         16.5.1       _sai_status_t       238         16.5.2       _sai_channel_mask       238         16.5.3       sai_protocol_t       238         16.5.4       sai_master_slave_t       239         16.5.5       sai_mono_stereo_t       239         16.5.6       sai_data_order_t       239         16.5.7       sai_clock_polarity_t       239         16.5.8       sai_sync_mode_t       239         16.5.9       sai_mclk_source_t       240         16.5.10       sai_bclk_source_t       240         16.5.11       _sai_interrupt_enable_t       240         16.5.12       _sai_data_enable_t       240         16.5.                                                                                                                                 | 16.2    | Typical use case                           | 229    |
| 16.2.2       SAI Send/receive using a DMA method       229         16.3       Data Structure Documentation       236         16.3.1       struct sai_config_t       236         16.3.2       struct sai_transfer_format_t       236         16.3.3       struct sai_transfer_t       237         16.3.4       struct_sai_handle       237         16.4       Macro Definition Documentation       238         16.5.1       SAI_XFER_QUEUE_SIZE       238         16.5.2       _sai_status_t       238         16.5.1       _sai_status_t       238         16.5.2       _sai_channel_mask       238         16.5.3       sai_protocol_t       238         16.5.4       sai_master_slave_t       239         16.5.5       sai_mono_stereo_t       239         16.5.6       sai_data_order_t       239         16.5.7       sai_clock_polarity_t       239         16.5.8       sai_sync_mode_t       239         16.5.9       sai_mclk_source_t       240         16.5.10       sai_bclk_source_t       240         16.5.11       _sai_interrupt_enable_t       240         16.5.12       _sai_data_enable_t       240         16.5.                                                                                                                                 | 16.2.1  | SAI Send/receive using an interrupt method | 229    |
| 16.3.1       struct sai_config_t       236         16.3.2       struct sai_transfer_format_t       236         16.3.3       struct sai_transfer_t       237         16.3.4       struct_sai_handle       237         16.4       Macro Definition Documentation       238         16.4.1       SAI_XFER_QUEUE_SIZE       238         16.5       Enumeration Type Documentation       238         16.5.1       _sai_status_t       238         16.5.2       _sai_channel_mask       238         16.5.3       sai_protocol_t       238         16.5.4       sai_master_slave_t       239         16.5.5       sai_mono_stereo_t       239         16.5.6       sai_data_order_t       239         16.5.7       sai_clock_polarity_t       239         16.5.8       sai_sync_mode_t       239         16.5.9       sai_mclk_source_t       240         16.5.10       sai_bclk_source_t       240         16.5.11       _sai_interrupt_enable_t       240         16.5.12       _sai_dma_enable_t       240         16.5.13       _sai_interrupt_enable_t       241         16.5.15       sai_iffo_packing_t       241         16.5.16 </td <td>16.2.2</td> <td></td> <td></td>                                                                                          | 16.2.2  |                                            |        |
| 16.3.2       struct sai_transfer_format_t       236         16.3.3       struct sai_transfer_t       237         16.3.4       struct_sai_handle       237         16.4       Macro Definition Documentation       238         16.4.1       SAI_XFER_QUEUE_SIZE       238         16.5       Enumeration Type Documentation       238         16.5.1       _sai_status_t       238         16.5.2       _sai_channel_mask       238         16.5.3       sai_protocol_t       238         16.5.4       sai_master_slave_t       239         16.5.5       sai_mono_stereo_t       239         16.5.6       sai_data_order_t       239         16.5.7       sai_clock_polarity_t       239         16.5.8       sai_sync_mode_t       239         16.5.9       sai_mclk_source_t       240         16.5.10       sai_bclk_source_t       240         16.5.11       _sai_interrupt_enable_t       240         16.5.12       _sai_dma_enable_t       240         16.5.13       _sai_flags       241         16.5.14       sai_reset_type_t       241         16.5.15       sai_fifo_packing_t       241         16.5.16       s                                                                                                                                          | 16.3    | Data Structure Documentation               | 236    |
| 16.3.3       struct sai_transfer_t       237         16.3.4       struct_sai_handle       237         16.4       Macro Definition Documentation       238         16.4.1       SAI_XFER_QUEUE_SIZE       238         16.5.2       Enumeration Type Documentation       238         16.5.1       _sai_status_t       238         16.5.2       _sai_channel_mask       238         16.5.3       sai_protocol_t       238         16.5.4       sai_master_slave_t       239         16.5.5       sai_mono_stereo_t       239         16.5.6       sai_data_order_t       239         16.5.7       sai_clock_polarity_t       239         16.5.8       sai_sync_mode_t       239         16.5.9       sai_melk_source_t       240         16.5.10       sai_bclk_source_t       240         16.5.11       _sai_interrupt_enable_t       240         16.5.12       _sai_dma_enable_t       240         16.5.13       _sai_flags       241         16.5.14       sai_reset_type_t       241         16.5.15       sai_fifo_packing_t       241         16.5.16       sai_sample_rate_t       241         16.5.17       sai_word_                                                                                                                                          | 16.3.1  | struct sai_config_t                        | 236    |
| 16.3.4       struct_sai_handle       237         16.4       Macro Definition Documentation       238         16.4.1       SAI_XFER_QUEUE_SIZE       238         16.5       Enumeration Type Documentation       238         16.5.1       _sai_status_t       238         16.5.2       _sai_channel_mask       238         16.5.3       sai_protocol_t       238         16.5.4       sai_master_slave_t       239         16.5.5       sai_mono_stereo_t       239         16.5.6       sai_data_order_t       239         16.5.7       sai_clock_polarity_t       239         16.5.8       sai_sync_mode_t       239         16.5.9       sai_mclk_source_t       240         16.5.10       sai_bclk_source_t       240         16.5.11       _sai_interrupt_enable_t       240         16.5.12       _sai_interrupt_enable_t       240         16.5.13       _sai_flags       241         16.5.14       sai_reset_type_t       241         16.5.15       sai_flo_packing_t       241         16.5.16       sai_sample_rate_t       241         16.5.17       sai_word_width_t       242         16.6       Function Docu                                                                                                                                          | 16.3.2  | struct sai_transfer_format_t               | 236    |
| 16.4       Macro Definition Documentation       238         16.4.1       SAI_XFER_QUEUE_SIZE       238         16.5       Enumeration Type Documentation       238         16.5.1       _sai_status_t       238         16.5.2       _sai_channel_mask       238         16.5.3       sai_protocol_t       238         16.5.4       sai_master_slave_t       239         16.5.5       sai_mono_stereo_t       239         16.5.6       sai_data_order_t       239         16.5.7       sai_clock_polarity_t       239         16.5.8       sai_sync_mode_t       239         16.5.9       sai_mclk_source_t       240         16.5.10       sai_bclk_source_t       240         16.5.11       _sai_interrupt_enable_t       240         16.5.12       _sai_adma_enable_t       240         16.5.13       _sai_flags       241         16.5.15       sai_ffo_packing_t       241         16.5.15       sai_ffo_packing_t       241         16.5.16       sai_sample_rate_t       241         16.5.17       sai_word_width_t       242         16.6       Function Documentation       242          16.6       SAI_T                                                                                                                                                  | 16.3.3  | struct sai_transfer_t                      | 237    |
| 16.4.1       SAI_XFER_QUEUE_SIZE       238         16.5       Enumeration Type Documentation       238         16.5.1       _sai_status_t       238         16.5.2       _sai_channel_mask       238         16.5.3       sai_protocol_t       238         16.5.4       sai_master_slave_t       239         16.5.5       sai_mono_stereo_t       239         16.5.6       sai_data_order_t       239         16.5.7       sai_clock_polarity_t       239         16.5.8       sai_sai_sync_mode_t       239         16.5.9       sai_mclk_source_t       240         16.5.10       sai_bclk_source_t       240         16.5.11       _sai_interrupt_enable_t       240         16.5.12       _sai_dma_enable_t       240         16.5.13       _sai_flags       241         16.5.14       sai_reset_type_t       241         16.5.15       sai_fifo_packing_t       241         16.5.16       sai_sample_rate_t       241         16.5.17       sai_word_width_t       242         16.6       Function Documentation       242         16.6       SAI_TxInit       242                                                                                                                                                                                             | 16.3.4  | struct _sai_handle                         | 237    |
| 16.5       Enumeration Type Documentation       238         16.5.1       _sai_status_t       238         16.5.2       _sai_channel_mask       238         16.5.3       sai_protocol_t       238         16.5.4       sai_master_slave_t       239         16.5.5       sai_mono_stereo_t       239         16.5.6       sai_data_order_t       239         16.5.7       sai_clock_polarity_t       239         16.5.8       sai_sync_mode_t       239         16.5.9       sai_melk_source_t       240         16.5.10       sai_belk_source_t       240         16.5.11       _sai_interrupt_enable_t       240         16.5.12       _sai_dma_enable_t       240         16.5.13       _sai_flags       241         16.5.14       sai_reset_type_t       241         16.5.15       sai_fifo_packing_t       241         16.5.16       sai_sample_rate_t       241         16.5.17       sai_word_width_t       242         16.6       Function Documentation       242         16.6.1       SAI_TxInit       242                                                                                                                                                                                                                                                  |         |                                            |        |
| 16.5.1       _sai_status_t       238         16.5.2       _sai_channel_mask       238         16.5.3       sai_protocol_t       238         16.5.4       sai_master_slave_t       239         16.5.5       sai_mono_stereo_t       239         16.5.6       sai_data_order_t       239         16.5.7       sai_clock_polarity_t       239         16.5.8       sai_sync_mode_t       239         16.5.9       sai_mclk_source_t       240         16.5.10       sai_bclk_source_t       240         16.5.11       _sai_interrupt_enable_t       240         16.5.12       _sai_dma_enable_t       240         16.5.13       _sai_flags       241         16.5.14       sai_reset_type_t       241         16.5.15       sai_flo_packing_t       241         16.5.16       sai_sample_rate_t       241         16.5.17       sai_word_width_t       242         16.6       Function Documentation       242         16.6.1       SAI_TxInit       242                                                                                                                                                                                                                                                                                                               | 16.4.1  | SAI_XFER_QUEUE_SIZE                        | 238    |
| 16.5.2       _sai_channel_mask       238         16.5.3       sai_protocol_t       238         16.5.4       sai_master_slave_t       239         16.5.5       sai_mono_stereo_t       239         16.5.6       sai_data_order_t       239         16.5.7       sai_clock_polarity_t       239         16.5.8       sai_sync_mode_t       239         16.5.9       sai_mclk_source_t       240         16.5.10       sai_bclk_source_t       240         16.5.11       _sai_interrupt_enable_t       240         16.5.12       _sai_dma_enable_t       240         16.5.13       _sai_flags       241         16.5.14       sai_reset_type_t       241         16.5.15       sai_fifo_packing_t       241         16.5.16       sai_sample_rate_t       241         16.5.17       sai_word_width_t       242         16.6       Function Documentation       242         16.6.1       SAI_TxInit       242                                                                                                                                                                                                                                                                                                                                                           |         | **                                         |        |
| 16.5.3       sai_protocol_t       238         16.5.4       sai_master_slave_t       239         16.5.5       sai_mono_stereo_t       239         16.5.6       sai_data_order_t       239         16.5.7       sai_clock_polarity_t       239         16.5.8       sai_sync_mode_t       239         16.5.9       sai_mclk_source_t       240         16.5.10       sai_bclk_source_t       240         16.5.11       _sai_interrupt_enable_t       240         16.5.12       _sai_dma_enable_t       240         16.5.13       _sai_flags       241         16.5.14       sai_reset_type_t       241         16.5.15       sai_fifo_packing_t       241         16.5.16       sai_sample_rate_t       241         16.5.17       sai_word_width_t       242         16.6       Function Documentation       242         16.6.1       SAI_TxInit       242                                                                                                                                                                                                                                                                                                                                                                                                            |         |                                            |        |
| 16.5.4       sai_master_slave_t       239         16.5.5       sai_mono_stereo_t       239         16.5.6       sai_data_order_t       239         16.5.7       sai_clock_polarity_t       239         16.5.8       sai_sync_mode_t       239         16.5.9       sai_mclk_source_t       240         16.5.10       sai_bclk_source_t       240         16.5.11       _sai_interrupt_enable_t       240         16.5.12       _sai_dma_enable_t       240         16.5.13       _sai_flags       241         16.5.14       sai_reset_type_t       241         16.5.15       sai_fifo_packing_t       241         16.5.16       sai_sample_rate_t       241         16.5.17       sai_word_width_t       242         16.6       Function Documentation       242         16.6.1       SAI_TxInit       242                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         | _sai_channel_mask                          | 238    |
| 16.5.5       sai_mono_stereo_t       239         16.5.6       sai_data_order_t       239         16.5.7       sai_clock_polarity_t       239         16.5.8       sai_sync_mode_t       239         16.5.9       sai_mclk_source_t       240         16.5.10       sai_bclk_source_t       240         16.5.11       _sai_interrupt_enable_t       240         16.5.12       _sai_dma_enable_t       240         16.5.13       _sai_flags       241         16.5.14       sai_reset_type_t       241         16.5.15       sai_fifo_packing_t       241         16.5.16       sai_sample_rate_t       241         16.5.17       sai_word_width_t       242         16.6       Function Documentation       242         16.6.1       SAI_TxInit       242                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |         | — <u>·</u>                                 |        |
| 16.5.6       sai_data_order_t       239         16.5.7       sai_clock_polarity_t       239         16.5.8       sai_sync_mode_t       239         16.5.9       sai_mclk_source_t       240         16.5.10       sai_bclk_source_t       240         16.5.11       _sai_interrupt_enable_t       240         16.5.12       _sai_dma_enable_t       240         16.5.13       _sai_flags       241         16.5.14       sai_reset_type_t       241         16.5.15       sai_fifo_packing_t       241         16.5.16       sai_sample_rate_t       241         16.5.17       sai_word_width_t       242         16.6       Function Documentation       242         16.6.1       SAI_TxInit       242                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 16.5.4  | sai_master_slave_t                         | 239    |
| 16.5.7       sai_clock_polarity_t       239         16.5.8       sai_sync_mode_t       240         16.5.9       sai_mclk_source_t       240         16.5.10       sai_bclk_source_t       240         16.5.11       _sai_interrupt_enable_t       240         16.5.12       _sai_dma_enable_t       240         16.5.13       _sai_flags       241         16.5.14       sai_reset_type_t       241         16.5.15       sai_fifo_packing_t       241         16.5.16       sai_sample_rate_t       241         16.5.17       sai_word_width_t       242         16.6       Function Documentation       242         16.6.1       SAI_TxInit       242                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |         |                                            |        |
| 16.5.8       sai_sync_mode_t       239         16.5.9       sai_mclk_source_t       240         16.5.10       sai_bclk_source_t       240         16.5.11       _sai_interrupt_enable_t       240         16.5.12       _sai_dma_enable_t       240         16.5.13       _sai_flags       241         16.5.14       sai_reset_type_t       241         16.5.15       sai_fifo_packing_t       241         16.5.16       sai_sample_rate_t       241         16.5.17       sai_word_width_t       242         16.6       Function Documentation       242         16.6.1       SAI_TxInit       242                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |         |                                            |        |
| 16.5.9       sai_mclk_source_t       240         16.5.10       sai_bclk_source_t       240         16.5.11       _sai_interrupt_enable_t       240         16.5.12       _sai_dma_enable_t       240         16.5.13       _sai_flags       241         16.5.14       sai_reset_type_t       241         16.5.15       sai_fifo_packing_t       241         16.5.16       sai_sample_rate_t       241         16.5.17       sai_word_width_t       242         16.6       Function Documentation       242         16.6.1       SAI_TxInit       242                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |         | · · · · · · · · · · · · · · · · · · ·      |        |
| 16.5.10       sai_bclk_source_t       240         16.5.11       _sai_interrupt_enable_t       240         16.5.12       _sai_dma_enable_t       240         16.5.13       _sai_flags       241         16.5.14       sai_reset_type_t       241         16.5.15       sai_fifo_packing_t       241         16.5.16       sai_sample_rate_t       241         16.5.17       sai_word_width_t       242         16.6       Function Documentation       242         16.6.1       SAI_TxInit       242                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |         |                                            |        |
| 16.5.11       _sai_interrupt_enable_t       240         16.5.12       _sai_dma_enable_t       240         16.5.13       _sai_flags       241         16.5.14       sai_reset_type_t       241         16.5.15       sai_fifo_packing_t       241         16.5.16       sai_sample_rate_t       241         16.5.17       sai_word_width_t       242         16.6       Function Documentation       242         16.6.1       SAI_TxInit       242                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |         |                                            |        |
| 16.5.12       _sai_dma_enable_t       240         16.5.13       _sai_flags       241         16.5.14       sai_reset_type_t       241         16.5.15       sai_fifo_packing_t       241         16.5.16       sai_sample_rate_t       241         16.5.17       sai_word_width_t       242         16.6       Function Documentation       242         16.6.1       SAI_TxInit       242                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |         |                                            |        |
| 16.5.13       _sai_flags       241         16.5.14       sai_reset_type_t       241         16.5.15       sai_fifo_packing_t       241         16.5.16       sai_sample_rate_t       241         16.5.17       sai_word_width_t       242         16.6       Function Documentation       242         16.6.1       SAI_TxInit       242                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |         | *                                          |        |
| 16.5.14       sai_reset_type_t       241         16.5.15       sai_fifo_packing_t       241         16.5.16       sai_sample_rate_t       241         16.5.17       sai_word_width_t       242         16.6       Function Documentation       242         16.6.1       SAI_TxInit       242                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |         |                                            |        |
| 16.5.15       sai_fifo_packing_t       241         16.5.16       sai_sample_rate_t       241         16.5.17       sai_word_width_t       242         16.6       Function Documentation       242         16.6.1       SAI_TxInit       242                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |         |                                            |        |
| 16.5.16       sai_sample_rate_t       241         16.5.17       sai_word_width_t       242         16.6       Function Documentation       242         16.6.1       SAI_TxInit       242                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |         | **                                         |        |
| 16.5.17       sai_word_width_t                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |                                            |        |
| 16.6         Function Documentation         242           16.6.1         SAI_TxInit         242                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |         | *                                          |        |
| 16.6.1 SAI_TxInit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 16.5.17 | sai_word_width_t                           | 242    |
| ——————————————————————————————————————                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         |                                            |        |
| 16.6.2 SAI_RxInit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |         |                                            |        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 16.6.2  | SAI_RxInit                                 | 242    |

# **Contents**

| Section |                               | Page   |
|---------|-------------------------------|--------|
| Number  | Title                         | Number |
| 16.6.3  | SAI_TxGetDefaultConfig        | 243    |
| 16.6.4  | SAI_RxGetDefaultConfig        | 243    |
| 16.6.5  | SAI_Deinit                    |        |
| 16.6.6  | SAI_TxReset                   | 244    |
| 16.6.7  | SAI_RxReset                   | 244    |
| 16.6.8  | SAI_TxEnable                  | 244    |
| 16.6.9  | SAI_RxEnable                  | 244    |
| 16.6.10 | SAI_TxGetStatusFlag           |        |
| 16.6.11 | SAI_TxClearStatusFlags        | 245    |
| 16.6.12 | SAI_RxGetStatusFlag           |        |
| 16.6.13 | SAI_RxClearStatusFlags        | 245    |
| 16.6.14 | SAI_TxSoftwareReset           | 246    |
| 16.6.15 | SAI_RxSoftwareReset           | 246    |
| 16.6.16 | SAI_TxSetChannelFIFOMask      | 246    |
| 16.6.17 | SAI_RxSetChannelFIFOMask      | 247    |
| 16.6.18 | SAI_TxSetDataOrder            | 247    |
| 16.6.19 | SAI_RxSetDataOrder            | 247    |
| 16.6.20 | SAI_TxSetBitClockPolarity     | 247    |
| 16.6.21 | SAI_RxSetBitClockPolarity     | 248    |
| 16.6.22 | SAI_TxSetFrameSyncPolarity    |        |
| 16.6.23 | SAI_RxSetFrameSyncPolarity    |        |
| 16.6.24 | SAI_TxSetFIFOPacking          |        |
| 16.6.25 | SAI_RxSetFIFOPacking          |        |
| 16.6.26 | SAI_TxSetFIFOErrorContinue    |        |
| 16.6.27 | SAI_RxSetFIFOErrorContinue    |        |
| 16.6.28 | SAI_TxEnableInterrupts        | 249    |
| 16.6.29 | SAI_RxEnableInterrupts        |        |
| 16.6.30 | SAI_TxDisableInterrupts       | 251    |
| 16.6.31 | SAI_RxDisableInterrupts       | 251    |
| 16.6.32 | SAI_TxEnableDMA               |        |
| 16.6.33 | SAI_RxEnableDMA               | 252    |
| 16.6.34 | SAI_TxGetDataRegisterAddress  | 252    |
| 16.6.35 | SAI_RxGetDataRegisterAddress  | 253    |
| 16.6.36 | SAI_TxSetFormat               | 253    |
| 16.6.37 | SAI_RxSetFormat               | 254    |
| 16.6.38 | SAI_WriteBlocking             | 254    |
| 16.6.39 | SAI_WriteMultiChannelBlocking | 254    |
| 16.6.40 | SAI_WriteData                 | 255    |
| 16.6.41 | SAI_ReadBlocking              | 255    |
| 16.6.42 | SAI_ReadMultiChannelBlocking  |        |
| 16.6.43 | SAI_ReadData                  | 256    |
| 16.6.44 | SAI_TransferTxCreateHandle    | 256    |
| 16.6.45 | SAI_TransferRxCreateHandle    | 257    |
| 16.6.46 | SAI_TransferTxSetFormat       | 257    |
| 16.6.47 | SAI_TransferRxSetFormat       | 258    |

MCUXpresso SDK API Reference Manual

NXP Semiconductors xiii

| Section | Contents                            | Page   |
|---------|-------------------------------------|--------|
| Number  | Title                               | Number |
| 16.6.48 | SAI_TransferSendNonBlocking         | 258    |
| 16.6.49 | SAI_TransferReceiveNonBlocking      | 259    |
| 16.6.50 | SAI_TransferGetSendCount            | 259    |
| 16.6.51 | SAI_TransferGetReceiveCount         | 260    |
| 16.6.52 | SAI_TransferAbortSend               | 260    |
| 16.6.53 | SAI_TransferAbortReceive            | 261    |
| 16.6.54 | SAI_TransferTerminateSend           | 261    |
| 16.6.55 | SAI_TransferTerminateReceive        | 261    |
| 16.6.56 | SAI_TransferTxHandleIRQ             | 262    |
| 16.6.57 | SAI_TransferRxHandleIRQ             | 262    |
| 16.7    | SAI DMA Driver                      | 263    |
| 16.8    | SAI EDMA Driver                     | 264    |
| 16.9    | SAI SDMA Driver                     | 265    |
| Chapter | SEMA4: Hardware Semaphores Driver   |        |
| 17.1    | Overview                            | 267    |
| 17.2    | Macro Definition Documentation      | 268    |
| 17.2.1  | SEMA4_GATE_NUM_RESET_ALL            |        |
| 17.3    | Function Documentation              | 268    |
| 17.3.1  | SEMA4_Init                          | 268    |
| 17.3.2  | SEMA4_Deinit                        | 268    |
| 17.3.3  | SEMA4_TryLock                       | 268    |
| 17.3.4  | SEMA4_Lock                          | 269    |
| 17.3.5  | SEMA4_Unlock                        | 269    |
| 17.3.6  | SEMA4_GetLockProc                   | 269    |
| 17.3.7  | SEMA4_ResetGate                     | 270    |
| 17.3.8  | SEMA4_ResetAllGates                 | 270    |
| 17.3.9  | SEMA4_EnableGateNotifyInterrupt     | 271    |
| 17.3.10 | SEMA4_DisableGateNotifyInterrupt    |        |
| 17.3.11 | SEMA4_GetGateNotifyStatus           |        |
| 17.3.12 | SEMA4_ResetGateNotify               |        |
| 17.3.13 | SEMA4_ResetAllGateNotify            |        |
| Chapter | TMU: Thermal Management Unit Driver |        |
| 18.1    | Overview                            | 275    |
| 18.2    | Typical use case                    | 275    |
| 18.2.1  | Monitor and report Configuration    |        |

# **Contents**

| Number Number | Title                             | Page<br>Number |
|---------------|-----------------------------------|----------------|
| 18.3          | Data Structure Documentation      | 277            |
| 18.3.1        | struct tmu_thresold_config_t      | 277            |
| 18.3.2        | struct tmu_interrupt_status_t     | 277            |
| 18.3.3        | struct tmu_config_t               | 278            |
| 18.4          | Macro Definition Documentation    | 278            |
| 18.4.1        | FSL_TMU_DRIVER_VERSION            | 278            |
| 18.5          | Enumeration Type Documentation    | 278            |
| 18.5.1        | _tmu_interrupt_enable             | 278            |
| 18.5.2        | _tmu_interrupt_status_flags       | 278            |
| 18.5.3        | _tmu_status_flags                 | 279            |
| 18.5.4        | tmu_average_low_pass_filter_t     | 279            |
| 18.6          | Function Documentation            | 279            |
| 18.6.1        | TMU_Init                          | 279            |
| 18.6.2        | TMU_Deinit                        | 279            |
| 18.6.3        | TMU_GetDefaultConfig              | 280            |
| 18.6.4        | TMU_Enable                        | 280            |
| 18.6.5        | TMU_EnableInterrupts              | 280            |
| 18.6.6        | TMU_DisableInterrupts             | 280            |
| 18.6.7        | TMU_GetInterruptStatusFlags       | 281            |
| 18.6.8        | TMU_ClearInterruptStatusFlags     | 281            |
| 18.6.9        | TMU_GetStatusFlags                | 281            |
| 18.6.10       | TMU_GetHighestTemperature         | 281            |
| 18.6.11       | TMU_GetLowestTemperature          | 282            |
| 18.6.12       | TMU_GetImmediateTemperature       | 282            |
| 18.6.13       | TMU_GetAverageTemperature         | 283            |
| 18.6.14       | TMU_SetHighTemperatureThresold    | 284            |
| 18.7          | Variable Documentation            | 284            |
| 18.7.1        | immediateThresoldEnable           | 284            |
| 18.7.2        | AverageThresoldEnable             | 284            |
| 18.7.3        | AverageCriticalThresoldEnable     | 284            |
| 18.7.4        | immediateThresoldValue            | 284            |
| 18.7.5        | averageThresoldValue              | 284            |
| 18.7.6        | averageCriticalThresoldValue      | 284            |
| 18.7.7        | interruptDetectMask               |                |
| 18.7.8        | immediateInterruptsSiteMask       | 285            |
| 18.7.9        | AverageInterruptsSiteMask         | 285            |
| 18.7.10       | AverageCriticalInterruptsSiteMask | 285            |
| 18.7.11       | monitorInterval                   |                |
| 18.7.12       | monitorSiteSelection              |                |
| 18.7.13       | averageLPF                        | 285            |

MCUXpresso SDK API Reference Manual

| C4!               | Contents                                     |                |  |
|-------------------|----------------------------------------------|----------------|--|
| Section<br>Number | Title                                        | Page<br>Number |  |
| Chapter           | WDOG: Watchdog Timer Driver                  |                |  |
| 19.1              | Overview                                     | 287            |  |
| 19.2              | Typical use case                             | 287            |  |
| 19.3              | Data Structure Documentation                 | 288            |  |
| 19.3.1            | struct wdog_work_mode_t                      | 288            |  |
| 19.3.2            | struct wdog_config_t                         | 288            |  |
| 19.4              | Enumeration Type Documentation               | 289            |  |
| 19.4.1            | _wdog_interrupt_enable                       | 289            |  |
| 19.4.2            | _wdog_status_flags                           | 289            |  |
| 19.5              | Function Documentation                       | 289            |  |
| 19.5.1            | WDOG_GetDefaultConfig                        | 289            |  |
| 19.5.2            | WDOG_Init                                    | 290            |  |
| 19.5.3            | WDOG_Deinit                                  | 290            |  |
| 19.5.4            | WDOG_Enable                                  | 290            |  |
| 19.5.5            | WDOG_Disable                                 | 291            |  |
| 19.5.6            | WDOG_TriggerSystemSoftwareReset              | 291            |  |
| 19.5.7            | WDOG_TriggerSoftwareSignal                   | 291            |  |
| 19.5.8            | WDOG_EnableInterrupts                        |                |  |
| 19.5.9            | WDOG_GetStatusFlags                          |                |  |
| 19.5.10           | WDOG_ClearInterruptStatus                    |                |  |
| 19.5.11           | WDOG_SetTimeoutValue                         |                |  |
| 19.5.12           | WDOG_SetInterrputTimeoutValue                |                |  |
| 19.5.13           | WDOG_DisablePowerDownEnable                  |                |  |
| 19.5.14           | WDOG_Refresh                                 | 295            |  |
| Chapter           | IOMUXC: Input/Output Multiplexing Controller |                |  |
| 20.1              | Overview                                     | 297            |  |
| 20.2              | Macro Definition Documentation               | 314            |  |
| 20.2.1            | FSL_IOMUXC_DRIVER_VERSION                    |                |  |
| 20.2.1            | rst_iowioac_briver_version                   | 314            |  |
| 20.3              | Function Documentation                       | 314            |  |
| 20.3.1            | IOMUXC_SetPinMux                             | 314            |  |
| 20.3.2            | IOMUXC_SetPinConfig                          |                |  |
| Chapter           | Debug Console                                |                |  |
| 21.1              | Overview                                     | 317            |  |
| 21.2              | Function groups                              | 317            |  |
|                   | Z mirror Browks                              |                |  |

| Section          | ection Contents                      |                |  |
|------------------|--------------------------------------|----------------|--|
| Number           | Title                                | Page<br>Number |  |
| 21.2.1<br>21.2.2 | Initialization                       |                |  |
| 21.3             | Typical use case                     | 321            |  |
| 21.4             | Macro Definition Documentation       | 323            |  |
| 21.4.1           | DEBUGCONSOLE_REDIRECT_TO_TOOLCHAIN   | 323            |  |
| 21.4.2           | DEBUGCONSOLE_REDIRECT_TO_SDK         | 324            |  |
| 21.4.3           | DEBUGCONSOLE_DISABLE                 | 324            |  |
| 21.4.4           | SDK_DEBUGCONSOLE                     | 324            |  |
| 21.4.5           | SDK_DEBUGCONSOLE_UART                | 324            |  |
| 21.4.6           | PRINTF                               | 324            |  |
| 21.5             | Function Documentation               | 324            |  |
| 21.5.1           | DbgConsole_Init                      | 324            |  |
| 21.5.2           | DbgConsole_Deinit                    |                |  |
| 21.5.3           | DbgConsole_Printf                    |                |  |
| 21.5.4           | DbgConsole_Putchar                   | 325            |  |
| 21.5.5           | DbgConsole_Scanf                     | 326            |  |
| 21.5.6           | DbgConsole_Getchar                   |                |  |
| 21.5.7           | DbgConsole_Flush                     |                |  |
| 21.5.8           | StrFormatPrintf                      |                |  |
| 21.5.9           | StrFormatScanf                       |                |  |
| 21.6             | Semihosting                          | 328            |  |
| 21.6.1           | Guide Semihosting for IAR            |                |  |
| 21.6.2           | Guide Semihosting for Keil µVision   |                |  |
| 21.6.3           | Guide Semihosting for MCUXpresso IDE |                |  |
| 21.6.4           | Guide Semihosting for ARMGCC         |                |  |
| 21.7             | <b>SWO</b>                           | 332            |  |
| 21.7.1           | Guide SWO for SDK                    |                |  |
| 21.7.2           | Guide SWO for Keil µVision           | 333            |  |
| 21.7.3           | Guide SWO for MCUXpresso IDE         |                |  |
| 21.7.4           | Guide SWO for ARMGCC                 |                |  |

xvii

# Chapter 1 Introduction

The MCUXpresso Software Development Kit (MCUXpresso SDK) is a collection of software enablement for NXP Microcontrollers that includes peripheral drivers, multicore support and integrated RTOS support for FreeRTOS<sup>TM</sup>. In addition to the base enablement, the MCUXpresso SDK is augmented with demo applications, driver example projects, and API documentation to help users quickly leverage the support provided by MCUXpresso SDK. The MCUXpresso SDK Web Builder is available to provide access to all MCUXpresso SDK packages. See the MCUXpresso Software Development Kit (SD-K) Release Notes (document MCUXSDKRN) in the Supported Devices section at MCUXpresso-SDK: Software Development Kit for MCUXpresso for details.

The MCUXpresso SDK is built with the following runtime software components:

- Arm<sup>®</sup> and DSP standard libraries, and CMSIS-compliant device header files which provide direct access to the peripheral registers.
- Peripheral drivers that provide stateless, high-performance, ease-of-use APIs. Communication drivers provide higher-level transactional APIs for a higher-performance option.
- RTOS wrapper driver built on top of MCUXpresso SDK peripheral drivers and leverage native RT-OS services to better comply to the RTOS cases.
- Real time operation systems (RTOS) for FreeRTOS OS.
- Stacks and middleware in source or object formats including:
  - CMSIS-DSP, a suite of common signal processing functions.
  - The MCUXpresso SDK comes complete with software examples demonstrating the usage of the peripheral drivers, RTOS wrapper drivers, middleware, and RTOSes.

All demo applications and driver examples are provided with projects for the following toolchains:

- IAR Embedded Workbench
- GNU Arm Embedded Toolchain

The peripheral drivers and RTOS driver wrappers can be used across multiple devices within the product family without modification. The configuration items for each driver are encapsulated into C language data structures. Device-specific configuration information is provided as part of the MCUXpresso SDK and need not be modified by the user. If necessary, the user is able to modify the peripheral driver and RTOS wrapper driver configuration during runtime. The driver examples demonstrate how to configure the drivers by passing the proper configuration data to the APIs. The folder structure is organized to reduce the total number of includes required to compile a project.

The rest of this document describes the API references in detail for the peripheral drivers and RT-OS wrapper drivers. For the latest version of this and other MCUXpresso SDK documents, see the mcuxpresso.nxp.com/apidoc/.

| Deliverable                               | Location                                                                                    |
|-------------------------------------------|---------------------------------------------------------------------------------------------|
| Demo Applications                         | <pre><install_dir>/boards/<board_name>/demo</board_name></install_dir></pre>                |
|                                           | apps                                                                                        |
| Driver Examples                           | <pre><install_dir>/boards/<board_name>/driver</board_name></install_dir></pre>              |
|                                           | examples                                                                                    |
| Documentation                             | <install_dir>/docs</install_dir>                                                            |
| Middleware                                | <install_dir>/middleware</install_dir>                                                      |
| Drivers                                   | <install_dir>/<device_name>/drivers/</device_name></install_dir>                            |
| CMSIS Standard Arm Cortex-M Headers, math | <install_dir>/CMSIS</install_dir>                                                           |
| and DSP Libraries                         |                                                                                             |
| Device Startup and Linker                 | <pre><install_dir>/<device_name>/<toolchain>/</toolchain></device_name></install_dir></pre> |
| MCUXpresso SDK Utilities                  | <install_dir>/devices/<device_name>/utilities</device_name></install_dir>                   |
| RTOS Kernel Code                          | <install_dir>/rtos</install_dir>                                                            |

Table 2: MCUXpresso SDK Folder Structure

# **Chapter 2 Driver errors status**

- kStatus\_ECSPI\_Busy = 6400
- kStatus\_ECSPI\_Idle = 6401
- kStatus\_ECSPI\_Error = 6402
- kStatus ECSPI HardwareOverFlow = 6403
- kStatus\_I2C\_Busy = 1100
- kStatus\_I2C\_Idle = 1101
- kStatus\_I2C\_Nak = 1102
- kStatus I2C ArbitrationLost = 1103
- kStatus\_I2C\_Timeout = 1104
- kStatus\_I2C\_Addr\_Nak = 1105
- kStatus\_UART\_TxBusy = 2800
- kStatus\_UART\_RxBusy = 2801
- kStatus\_UART\_TxIdle = 2802
- kStatus\_UART\_RxIdle = 2803
- kStatus\_UART\_TxWatermarkTooLarge = 2804
- kStatus\_UART\_RxWatermarkTooLarge = 2805
- kStatus\_UART\_FlagCannotClearManually = 2806
- kStatus\_UART\_Error = 2807
- kStatus\_UART\_RxRingBufferOverrun = 2808
- kStatus\_UART\_RxHardwareOverrun = 2809
- kStatus\_UART\_NoiseError = 2810
- kStatus\_UART\_FramingError = 2811
- kStatus UART ParityError = 2812
- kStatus\_UART\_BaudrateNotSupport = 2813
- kStatus\_UART\_BreakDetect = 2814
- kStatus\_QSPI\_Idle = 4500
- kStatus\_QSPI\_Busy = 4501
- kStatus\_QSPI\_Error = 4502
- kStatus\_SAI\_TxBusy = 1900
- kStatus\_SAI\_RxBusy = 1901
- kStatus\_SAI\_TxError = 1902
- kStatus\_SAI\_RxError = 1903
- kStatus\_SAI\_QueueFull = 1904
- kStatus\_SAI\_TxIdle = 1905kStatus\_SAI\_RxIdle = 1906

3

# Chapter 3 Architectural Overview

This chapter provides the architectural overview for the MCUXpresso Software Development Kit (MCUXpresso SDK). It describes each layer within the architecture and its associated components.

#### Overview

The MCUXpresso SDK architecture consists of five key components listed below.

- 1. The Arm Cortex Microcontroller Software Interface Standard (CMSIS) CORE compliance device-specific header files, SOC Header, and CMSIS math/DSP libraries.
- 2. Peripheral Drivers
- 3. Real-time Operating Systems (RTOS)
- 4. Stacks and Middleware that integrate with the MCUXpresso SDK
- 5. Demo Applications based on the MCUXpresso SDK



Figure 1: MCUXpresso SDK Block Diagram

#### MCU header files

Each supported MCU device in the MCUXpresso SDK has an overall System-on Chip (SoC) memory-

mapped header file. This header file contains the memory map and register base address for each peripheral and the IRQ vector table with associated vector numbers. The overall SoC header file provides access to the peripheral registers through pointers and predefined bit masks. In addition to the overall SoC memory-mapped header file, the MCUXpresso SDK includes a feature header file for each device. The feature header file allows NXP to deliver a single software driver for a given peripheral. The feature file ensures that the driver is properly compiled for the target SOC.

# **CMSIS Support**

Along with the SoC header files and peripheral extension header files, the MCUXpresso SDK also includes common CMSIS header files for the Arm Cortex-M core and the math and DSP libraries from the latest CMSIS release. The CMSIS DSP library source code is also included for reference.

# **MCUXpresso SDK Peripheral Drivers**

The MCUXpresso SDK peripheral drivers mainly consist of low-level functional APIs for the MCU product family on-chip peripherals and also of high-level transactional APIs for some bus drivers/DM-A driver/eDMA driver to quickly enable the peripherals and perform transfers.

All MCUXpresso SDK peripheral drivers only depend on the CMSIS headers, device feature files, fsl\_common.h, and fsl\_clock.h files so that users can easily pull selected drivers and their dependencies into projects. With the exception of the clock/power-relevant peripherals, each peripheral has its own driver. Peripheral drivers handle the peripheral clock gating/ungating inside the drivers during initialization and deinitialization respectively.

Low-level functional APIs provide common peripheral functionality, abstracting the hardware peripheral register accesses into a set of stateless basic functional operations. These APIs primarily focus on the control, configuration, and function of basic peripheral operations. The APIs hide the register access details and various MCU peripheral instantiation differences so that the application can be abstracted from the low-level hardware details. The API prototypes are intentionally similar to help ensure easy portability across supported MCUXpresso SDK devices.

Transactional APIs provide a quick method for customers to utilize higher-level functionality of the peripherals. The transactional APIs utilize interrupts and perform asynchronous operations without user intervention. Transactional APIs operate on high-level logic that requires data storage for internal operation context handling. However, the Peripheral Drivers do not allocate this memory space. Rather, the user passes in the memory to the driver for internal driver operation. Transactional APIs ensure the NVIC is enabled properly inside the drivers. The transactional APIs do not meet all customer needs, but provide a baseline for development of custom user APIs.

Note that the transactional drivers never disable an NVIC after use. This is due to the shared nature of interrupt vectors on devices. It is up to the user to ensure that NVIC interrupts are properly disabled after usage is complete.

## **Interrupt handling for transactional APIs**

A double weak mechanism is introduced for drivers with transactional API. The double weak indicates two levels of weak vector entries. See the examples below:

PUBWEAK SPI0\_IRQHandler
PUBWEAK SPI0\_DriverIRQHandler
SPI0\_IRQHandler

```
LDR R0, =SPI0_DriverIRQHandler
BX R0
```

The first level of the weak implementation are the functions defined in the vector table. In the devices/<-DEVICE\_NAME>/<TOOLCHAIN>/startup\_<DEVICE\_NAME>.s/.S file, the implementation of the first layer weak function calls the second layer of weak function. The implementation of the second layer weak function (ex. SPI0\_DriverIRQHandler) jumps to itself (B). The MCUXpresso SDK drivers with transactional APIs provide the reimplementation of the second layer function inside of the peripheral driver. If the MCUXpresso SDK drivers with transactional APIs are linked into the image, the SPI0\_DriverIRQHandler is replaced with the function implemented in the MCUXpresso SDK SPI driver.

The reason for implementing the double weak functions is to provide a better user experience when using the transactional APIs. For drivers with a transactional function, call the transactional APIs and the drivers complete the interrupt-driven flow. Users are not required to redefine the vector entries out of the box. At the same time, if users are not satisfied by the second layer weak function implemented in the MCU-Xpresso SDK drivers, users can redefine the first layer weak function and implement their own interrupt handler functions to suit their implementation.

The limitation of the double weak mechanism is that it cannot be used for peripherals that share the same vector entry. For this use case, redefine the first layer weak function to enable the desired peripheral interrupt functionality. For example, if the MCU's UART0 and UART1 share the same vector entry, redefine the UART0\_UART1\_IRQHandler according to the use case requirements.

#### **Feature Header Files**

The peripheral drivers are designed to be reusable regardless of the peripheral functional differences from one MCU device to another. An overall Peripheral Feature Header File is provided for the MCUXpresso SDK-supported MCU device to define the features or configuration differences for each sub-family device.

### **Application**

See the Getting Started with MCUXpresso SDK document (MCUXSDKGSUG).

# Chapter 4 Trademarks

Information in this document is provided solely to enable system and software implementers to use NXP products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits based on the information in this document.

How to Reach Us:

Home Page: nxp.com

Web Support: nxp.com/support

NXP makes no warranty, representation, or guarantee regarding the suitability of its products for any particular purpose, nor does NXP assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters that may be provided in NXP data sheets and/or specifications can and do vary in different applications, and actual performance may vary over time. All operating parameters, including "typicals," must be validated for each customer application by customer's technical experts. NXP does not convey any license under its patent rights nor the rights of others. NXP sells products pursuant to standard terms and conditions of sale, which can be found at the following address: {http://www.nxp.com/SalesTermsandConditions}.

NXP, the NXP logo, NXP SECURE CONNECTIONS FOR A SMARTER WORLD, COOLFLUX, EM-BRACE, GREENCHIP, HITAG, I2C BUS, ICODE, JCOP, LIFE VIBES, MIFARE, MIFARE CLASSIC, MIFARE DESFire, MIFARE PLUS, MIFARE FLEX, MANTIS, MIFARE ULTRALIGHT, MIFARE4M-OBILE, MIGLO, NTAG, ROADLINK, SMARTLX, SMARTMX, STARPLUG, TOPFET, TRENCHM-OS, UCODE, Freescale, the Freescale logo, AltiVec, C-5, CodeTEST, CodeWarrior, ColdFire, ColdFire+, C-Ware, the Energy Efficient Solutions logo, Kinetis, Layerscape, MagniV, mobileGT, PEG, PowerQUI-CC, Processor Expert, QorIQ, QorIQ Qonverge, Ready Play, SafeAssure, the SafeAssure logo, StarCore, Symphony, VortiQa, Vybrid, Airfast, BeeKit, BeeStack, CoreNet, Flexis, MXC, Platform in a Package, QUICC Engine, SMARTMOS, Tower, TurboLink, and UMEMS are trademarks of NXP B.V. All other product or service names are the property of their respective owners. AMBA, Arm, Arm7, Arm7TD-MI, Arm9, Arm11, Artisan, big.LITTLE, Cordio, CoreLink, CoreSight, Cortex, DesignStart, Dynam-IQ, Jazelle, Keil, Mali, Mbed, Mbed Enabled, NEON, POP, RealView, SecurCore, Socrates, Thumb, TrustZone, ULINK, ULINK2, ULINK-ME, ULINK-PLUS, ULINKpro, Vision, Versatile are trademarks or registered trademarks of Arm Limited (or its subsidiaries) in the US and/or elsewhere. The related technology may be protected by any or all of patents, copyrights, designs and trade secrets. All rights reserved. Oracle and Java are registered trademarks of Oracle and/or its affiliates. The Power Architecture and Power.org word marks and the Power and Power.org logos and related marks are trademarks and service marks licensed by Power.org.

© 2018 NXP B.V.

# Chapter 5 Clock Driver

### 5.1 Overview

The MCUXpresso SDK provides APIs for MCUXpresso SDK devices' clock operation.

## **Data Structures**

• struct osc\_config\_t

OSC configuration structure. More...

struct ccm\_analog\_frac\_pll\_config\_t

Fractional-N PLL configuration. More...

• struct ccm\_analog\_sscg\_pll\_config\_t

SSCG PLL configuration. More...

## **Macros**

#define OSC25M\_CLK\_FREQ 25000000U

XTAL 25M clock frequency.

#define OSC27M\_CLK\_FREQ 27000000U

XTAL 27M clock frequency.

#define HDMI\_PHY\_27M\_FREQ 27000000U

HDMI PHY 27M clock frequency.

#define CLKPN\_FREQ 0U

clock1PN frequency.

#define ECSPI\_CLOCKS

Clock ip name array for ECSPI.

#define GPIO CLOCKS

Clock ip name array for GPIO.

#define GPT\_CLOCKS

Clock ip name array for GPT.

#define I2C\_CLOCKS

Clock ip name array for I2C.

#define IOMUX\_CLOCKS

Clock ip name array for IOMUX.

#define PWM\_CLOCKS

Clock ip name array for PWM.

#define RDC\_CLOCKS

Clock ip name array for RDC.

#define SAI CLOCKS

Clock ip name array for SAI.

#define RDC\_SEMA42\_CLOCKS

Clock ip name array for RDC SEMA42.

#define UART CLOCKS

Clock ip name array for UART.

• #define USDHC CLOCKS

### Overview

```
Clock ip name array for USDHC.
• #define WDOG_CLOCKS
     Clock ip name array for WDOG.

    #define TMU_CLOCKS

     Clock ip name array for TEMPSENSOR.

    #define SDMA CLOCKS

     Clock ip name array for SDMA.
• #define MU CLOCKS
     Clock ip name array for MU.

    #define QSPI_CLOCKS

     Clock ip name array for QSPI.
• #define CCM_BIT_FIELD_EXTRACTION(val, mask, shift) (((val)&mask) >> shift)
     CCM reg macros to extract corresponding registers bit field.
• #define CCM REG OFF(root, off) (*((volatile uint32 t *)((uint32 t)root + off)))
     CCM reg macros to map corresponding registers.
• #define CCM_ANALOG_TUPLE(reg, shift) ((((uint32_t)(&((CCM_ANALOG_Type *)0U)->reg)
  & 0xFFFFU) << 16U) | (shift))
     CCM ANALOG tuple macros to map corresponding registers and bit fields.
• #define CCM TUPLE(ccgr, root) (ccgr << 16U | root)
     CCM CCGR and root tuple.

    #define kCLOCK_CoreSysClk kCLOCK_CoreM4Clk

     For compatible with other platforms without CCM.
• #define CLOCK_GetCoreSysClkFreq CLOCK_GetCoreM4Freq
     For compatible with other platforms without CCM.
```

# **Enumerations**

```
    enum clock_name_t {
        kCLOCK_CoreM4Clk,
        kCLOCK_AxiClk,
        kCLOCK_AhbClk,
        kCLOCK_IpgClk }
        Clock name used to get clock frequency.
    enum clock_ip_name_t { ,
```

```
kCLOCK Debug = CCM TUPLE(4U, 32U),
kCLOCK_Dram = CCM_TUPLE(5U, 64U),
kCLOCK Ecspi1 = CCM TUPLE(7U, 101U),
kCLOCK_Ecspi2 = CCM_TUPLE(8U, 102U),
kCLOCK Ecspi3 = CCM TUPLE(9U, 131U),
kCLOCK Gpio1 = CCM TUPLE(11U, 33U),
kCLOCK_Gpio2 = CCM_TUPLE(12U, 33U),
kCLOCK_Gpio3 = CCM_TUPLE(13U, 33U),
kCLOCK Gpio4 = CCM TUPLE(14U, 33U),
kCLOCK_Gpio5 = CCM_TUPLE(15U, 33U),
kCLOCK\_Gpt1 = CCM\_TUPLE(16U, 107U),
kCLOCK Gpt2 = CCM TUPLE(17U, 108U),
kCLOCK\_Gpt3 = CCM\_TUPLE(18U, 109U),
kCLOCK Gpt4 = CCM TUPLE(19U, 110U),
kCLOCK_Gpt5 = CCM_TUPLE(20U, 111U),
kCLOCK Gpt6 = CCM TUPLE(21U, 112U),
kCLOCK I2c1 = CCM TUPLE(23U, 90U),
kCLOCK_12c2 = CCM_TUPLE(24U, 91U),
kCLOCK_12c3 = CCM_TUPLE(25U, 92U),
kCLOCK I2c4 = CCM TUPLE(26U, 93U),
kCLOCK_Iomux0 = CCM_TUPLE(27U, 33U),
kCLOCK Iomux1 = CCM TUPLE(28U, 33U),
kCLOCK_Iomux2 = CCM_TUPLE(29U, 33U),
kCLOCK Iomux3 = CCM TUPLE(30U, 33U),
kCLOCK Iomux4 = CCM TUPLE(31U, 33U),
kCLOCK_M4 = CCM_TUPLE(32U, 1U),
kCLOCK_Mu = CCM_TUPLE(33U, 33U),
kCLOCK Ocram = CCM TUPLE(35U, 16U),
kCLOCK_OcramS = CCM_TUPLE(36U, 32U),
kCLOCK_Pwm1 = CCM_TUPLE(40U, 103U),
kCLOCK_Pwm2 = CCM_TUPLE(41U, 104U),
kCLOCK_Pwm3 = CCM_TUPLE(42U, 105U),
kCLOCK Pwm4 = CCM TUPLE(43U, 106U),
kCLOCK_Qspi = CCM_TUPLE(47U, 87U),
kCLOCK Rdc = CCM TUPLE(49U, 33U),
kCLOCK Sai1 = CCM TUPLE(51U, 75U),
kCLOCK_Sai2 = CCM_TUPLE(52U, 76U),
kCLOCK_Sai3 = CCM_TUPLE(53U, 77U),
kCLOCK Sai4 = CCM TUPLE(54U, 78U),
kCLOCK_Sai5 = CCM_TUPLE(55U, 79U),
kCLOCK Sai6 = CCM TUPLE(56U, 80U),
kCLOCK_Sdma1 = CCM_TUPLE(58U, 33U),
kCLOCK Sdma2 = CCM TUPLE(59U, 35U),
kCLOCK Sec Debug = CCM TUPLE(60U, 33U),
kCLOCK_Sema42_1 = CCM_TUPLE(61U, 33U),
kCLOCK_Sema42_2 = CCM_TUPLE(62U, 33U),
kCLOCK_Sim_display MCCMnFesFd_SORUAPOReference Manual
```

NXP semiconductors m = CCM\_TUPLE(65U, 32U), kCLOCK\_Sim\_main = CCM\_TUPLE(66U, 16U),

### Overview

```
kCLOCK TempSensor = CCM TUPLE(98U, 0xFFFF) }
    CCM CCGR gate control.
enum clock_root_control_t {
 kCLOCK RootM4 = (uint32 t)(&(CCM)->ROOT[1].TARGET ROOT),
 kCLOCK_RootAxi = (uint32_t)(&(CCM)->ROOT[16].TARGET_ROOT),
 kCLOCK RootNoc = (uint32 t)(&(CCM)->ROOT[26].TARGET ROOT),
 kCLOCK RootAhb = (uint32 t)(&(CCM)->ROOT[32].TARGET ROOT),
 kCLOCK_RootIpg = (uint32_t)(\&(CCM)->ROOT[33].TARGET_ROOT),
 kCLOCK RootDramAlt = (uint32 t)(&(CCM)->ROOT[64].TARGET ROOT),
 kCLOCK RootSai1 = (uint32 t)(&(CCM)->ROOT[75].TARGET ROOT),
 kCLOCK_RootSai2 = (uint32_t)(\&(CCM)->ROOT[76].TARGET_ROOT),
 kCLOCK_RootSai3 = (uint32_t)(&(CCM)->ROOT[77].TARGET_ROOT),
 kCLOCK RootSai4 = (uint32 t)(&(CCM)->ROOT[78].TARGET ROOT),
 kCLOCK RootSai5 = (uint32 t)(&(CCM)->ROOT[79].TARGET ROOT),
 kCLOCK RootSai6 = (uint32 t)(&(CCM)->ROOT[80].TARGET ROOT),
 kCLOCK_RootQspi = (uint32_t)(&(CCM)->ROOT[87].TARGET_ROOT),
 kCLOCK RootI2c1 = (uint32 t)(&(CCM)->ROOT[90].TARGET ROOT),
 kCLOCK RootI2c2 = (uint32 t)(&(CCM)->ROOT[91].TARGET ROOT),
 kCLOCK_RootI2c3 = (uint32_t)(\&(CCM)->ROOT[92].TARGET_ROOT),
 kCLOCK_RootI2c4 = (uint32_t)(\&(CCM)->ROOT[93].TARGET_ROOT),
 kCLOCK RootUart1 = (uint32 t)(&(CCM)->ROOT[94].TARGET ROOT),
 kCLOCK_RootUart2 = (uint32_t)(&(CCM)->ROOT[95].TARGET_ROOT),
 kCLOCK RootUart3 = (uint32 t)(&(CCM)->ROOT[96].TARGET ROOT),
 kCLOCK_RootUart4 = (uint32_t)(&(CCM)->ROOT[97].TARGET_ROOT),
 kCLOCK RootEcspi1 = (uint32 t)(&(CCM)->ROOT[101].TARGET ROOT),
 kCLOCK RootEcspi2 = (uint32 t)(&(CCM)->ROOT[102].TARGET ROOT),
 kCLOCK_RootEcspi3 = (uint32_t)(&(CCM)->ROOT[131].TARGET_ROOT),
 kCLOCK RootPwm1 = (uint32 t)(&(CCM)->ROOT[103].TARGET ROOT),
 kCLOCK_RootPwm2 = (uint32_t)(\&(CCM)->ROOT[104].TARGET_ROOT),
 kCLOCK_RootPwm3 = (uint32_t)(&(CCM)->ROOT[105].TARGET_ROOT),
 kCLOCK RootPwm4 = (uint32 t)(&(CCM)->ROOT[106].TARGET ROOT),
 kCLOCK RootGpt1 = (uint32 t)(&(CCM)->ROOT[107].TARGET ROOT),
 kCLOCK RootGpt2 = (uint32 t)(&(CCM)->ROOT[108].TARGET ROOT),
 kCLOCK RootGpt3 = (uint32_t)(&(CCM)->ROOT[109].TARGET_ROOT),
 kCLOCK_RootGpt4 = (uint32_t)(&(CCM)->ROOT[110].TARGET_ROOT),
 kCLOCK RootGpt5 = (uint32 t)(&(CCM)->ROOT[111].TARGET ROOT),
 kCLOCK_RootGpt6 = (uint32_t)(&(CCM)->ROOT[112].TARGET_ROOT),
 kCLOCK_RootWdog = (uint32_t)(&(CCM)->ROOT[114].TARGET_ROOT) }
   ccm root name used to get clock frequency.
enum clock_rootmux_m4_clk_sel_t {
```

MCUXpresso SDK API Reference Manual

15

```
kCLOCK M4RootmuxOsc25m = 0U
 kCLOCK_M4RootmuxSysPll2Div5 = 1U,
 kCLOCK_M4RootmuxSysPll2Div4 = 2U
 kCLOCK_M4RootmuxSysPll1Div3 = 3U,
 kCLOCK M4RootmuxSysPll1 = 4U,
 kCLOCK M4RootmuxAudioPll1 = 5U,
 kCLOCK_M4RootmuxVideoPll1 = 6U,
 kCLOCK_M4RootmuxSysPll3 = 7U }
    Root clock select enumeration for ARM Cortex-M4 core.

    enum clock rootmux axi clk sel t {

 kCLOCK_AxiRootmuxOsc25m = 0U,
 kCLOCK_AxiRootmuxSysPll2Div3 = 1U,
 kCLOCK_AxiRootmuxSysPll1 = 2U,
 kCLOCK_AxiRootmuxSysPll2Div4 = 3U,
 kCLOCK AxiRootmuxSysPll2 = 4U,
 kCLOCK_AxiRootmuxAudioPll1 = 5U,
 kCLOCK AxiRootmuxVideoPll1 = 6U,
 kCLOCK AxiRootmuxSysPll1Div8 = 7U }
    Root clock select enumeration for AXI bus.
enum clock_rootmux_ahb_clk_sel_t {
 kCLOCK AhbRootmuxOsc25m = 0U,
 kCLOCK_AhbRootmuxSysPll1Div6 = 1U,
 kCLOCK_AhbRootmuxSysPll1 = 2U,
 kCLOCK_AhbRootmuxSysPll1Div2 = 3U
 kCLOCK_AhbRootmuxSysPll2Div8 = 4U,
 kCLOCK AhbRootmuxSysPll3 = 5U,
 kCLOCK_AhbRootmuxAudioPll1 = 6U,
 kCLOCK_AhbRootmuxVideoPll1 = 7U }
    Root clock select enumeration for AHB bus.
enum clock_rootmux_qspi_clk_sel_t {
 kCLOCK_QspiRootmuxOsc25m = 0U,
 kCLOCK_QspiRootmuxSysPll1Div2 = 1U,
 kCLOCK_QspiRootmuxSysPll1 = 2U,
 kCLOCK_QspiRootmuxSysPll2Div2 = 3U,
 kCLOCK_QspiRootmuxAudioPll2 = 4,
 kCLOCK_QspiRootmuxSysPll1Div3 = 5U,
 kCLOCK_QspiRootmuxSysPll3 = 6U,
 kCLOCK QspiRootmuxSysPll1Div8 = 7U }
    Root clock select enumeration for QSPI peripheral.
enum clock_rootmux_ecspi_clk_sel_t {
```

### Overview

```
kCLOCK EcspiRootmuxOsc25m = 0U,
 kCLOCK_EcspiRootmuxSysPll2Div5 = 1U,
 kCLOCK_EcspiRootmuxSysPll1Div20 = 2U,
 kCLOCK_EcspiRootmuxSysPll1Div5 = 3U,
 kCLOCK EcspiRootmuxSysPll1 = 4U,
 kCLOCK_EcspiRootmuxSysPll3 = 5U,
 kCLOCK_EcspiRootmuxSysPll2Div4 = 6U,
 kCLOCK_EcspiRootmuxAudioPll2 = 7U }
    Root clock select enumeration for ECSPI peripheral.

    enum clock rootmux i2c clk sel t {

 kCLOCK_12cRootmuxOsc25m = 0U,
 kCLOCK_I2cRootmuxSysPll1Div5 = 1U,
 kCLOCK_I2cRootmuxSysPll2Div20 = 2U,
 kCLOCK_I2cRootmuxSysPll3 = 3U,
 kCLOCK I2cRootmuxAudioPll1 = 4U,
 kCLOCK_I2cRootmuxVideoPll1 = 5U,
 kCLOCK I2cRootmuxAudioPll2 = 6U,
 kCLOCK I2cRootmuxSysPll1Div6 = 7U }
    Root clock select enumeration for I2C peripheral.
enum clock_rootmux_uart_clk_sel_t {
 kCLOCK\ UartRootmuxOsc25m = 0U
 kCLOCK_UartRootmuxSysPll1Div10 = 1U,
 kCLOCK_UartRootmuxSysPll2Div5 = 2U,
 kCLOCK_UartRootmuxSysPll2Div10 = 3U,
 kCLOCK_UartRootmuxSysPl13 = 4U,
 kCLOCK UartRootmuxExtClk2 = 5U,
 kCLOCK_UartRootmuxExtClk34 = 6U,
 kCLOCK_UartRootmuxAudioPll2 = 7U }
    Root clock select enumeration for UART peripheral.
enum clock_rootmux_gpt_t {
 kCLOCK_GptRootmuxOsc25m = 0U,
 kCLOCK_GptRootmuxSystemPll2Div10 = 1U,
 kCLOCK_GptRootmuxSysPll1Div2 = 2U,
 kCLOCK_GptRootmuxSysPll1Div20 = 3U,
 kCLOCK GptRootmuxVideoPll1 = 4U,
 kCLOCK_GptRootmuxSystemPll1Div10 = 5U,
 kCLOCK_GptRootmuxAudioPll1 = 6U,
 kCLOCK GptRootmuxExtClk123 = 7U }
    Root clock select enumeration for GPT peripheral.
enum clock_rootmux_wdog_clk_sel_t {
```

```
kCLOCK WdogRootmuxOsc25m = 0U,
 kCLOCK_WdogRootmuxSysPll1Div6 = 1U,
 kCLOCK_WdogRootmuxSysPll1Div5 = 2U,
 kCLOCK_WdogRootmuxVpuPll = 3U,
 kCLOCK WdogRootmuxSystemPll2Div8 = 4U,
 kCLOCK_WdogRootmuxSystemPll3 = 5U,
 kCLOCK_WdogRootmuxSystemPll1Div10 = 6U,
 kCLOCK_WdogRootmuxSystemPll2Div6 = 7U }
    Root clock select enumeration for WDOG peripheral.

    enum clock rootmux Pwm clk sel t {

 kCLOCK_PwmRootmuxOsc25m = 0U,
 kCLOCK_PwmRootmuxSysPll2Div10 = 1U,
 kCLOCK_PwmRootmuxSysPll1Div5 = 2U,
 kCLOCK_PwmRootmuxSysPll1Div20 = 3U,
 kCLOCK PwmRootmuxSystemPll3 = 4U,
 kCLOCK_PwmRootmuxExtClk12 = 5U,
 kCLOCK PwmRootmuxSystemPll1Div10 = 6U,
 kCLOCK PwmRootmuxVideoPll1 = 7U }
    Root clock select enumeration for PWM peripheral.
enum clock_rootmux_sai_clk_sel_t {
 kCLOCK SaiRootmuxOsc25m = 0U,
 kCLOCK_SaiRootmuxAudioPll1 = 1U,
 kCLOCK_SaiRootmuxAudioPll2 = 2U
 kCLOCK SaiRootmuxVideoPll1 = 3U,
 kCLOCK_SaiRootmuxSysPll1Div6 = 4U,
 kCLOCK SaiRootmuxOsc27m = 5U,
 kCLOCK_SaiRootmuxExtClk123 = 6U,
 kCLOCK_SaiRootmuxExtClk234 = 7U }
    Root clock select enumeration for SAI peripheral.
enum clock_rootmux_noc_clk_sel_t {
 kCLOCK_NocRootmuxOsc25m = 0U,
 kCLOCK_NocRootmuxSysPll1 = 1U,
 kCLOCK_NocRootmuxSysPl13 = 2U,
 kCLOCK NocRootmuxSysPl12 = 3U,
 kCLOCK NocRootmuxSysPll2Div2 = 4U,
 kCLOCK_NocRootmuxAudioPll1 = 5U,
 kCLOCK NocRootmuxVideoPll1 = 6U,
 kCLOCK NocRootmuxAudioPll2 = 7U }
    Root clock select enumeration for NOC CLK.
enum clock_pll_gate_t {
```

MCUXpresso SDK API Reference Manual

### Overview

```
kCLOCK_ArmPllGate = (uint32_t)(&(CCM)->PLL_CTRL[12].PLL_CTRL),
 kCLOCK_GpuPllGate = (uint32_t)(&(CCM)->PLL_CTRL[13].PLL_CTRL),
 kCLOCK VpuPllGate = (uint32 t)(&(CCM)->PLL CTRL[14].PLL CTRL),
 kCLOCK_DramPllGate = (uint32_t)(&(CCM)->PLL_CTRL[15].PLL_CTRL),
 kCLOCK SysPll1Gate = (uint32 t)(&(CCM)->PLL CTRL[16].PLL CTRL),
 kCLOCK SysPll1Div2Gate = (uint32 t)(&(CCM)->PLL CTRL[17].PLL CTRL),
 kCLOCK_SysPll1Div3Gate = (uint32_t)(&(CCM)->PLL_CTRL[18].PLL_CTRL),
 kCLOCK_SysPll1Div4Gate = (uint32_t)(&(CCM)->PLL_CTRL[19].PLL_CTRL),
 kCLOCK SysPll1Div5Gate = (uint32 t)(&(CCM)->PLL CTRL[20].PLL CTRL),
 kCLOCK_SysPll1Div6Gate = (uint32_t)(&(CCM)->PLL_CTRL[21].PLL_CTRL),
 kCLOCK_SysPll1Div8Gate = (uint32_t)(&(CCM)->PLL_CTRL[22].PLL_CTRL),
 kCLOCK SysPll1Div10Gate = (uint32 t)(&(CCM)->PLL CTRL[23].PLL CTRL),
 kCLOCK_SysPll1Div20Gate = (uint32_t)(&(CCM)->PLL_CTRL[24].PLL_CTRL),
 kCLOCK SysPll2Gate = (uint32 t)(&(CCM)->PLL CTRL[25].PLL CTRL),
 kCLOCK_SysPll2Div2Gate = (uint32_t)(&(CCM)->PLL_CTRL[26].PLL_CTRL),
 kCLOCK SysPll2Div3Gate = (uint32 t)(&(CCM)->PLL CTRL[27].PLL CTRL),
 kCLOCK SysPll2Div4Gate = (uint32 t)(&(CCM)->PLL CTRL[28].PLL CTRL),
 kCLOCK_SysPll2Div5Gate = (uint32_t)(&(CCM)->PLL_CTRL[29].PLL_CTRL),
 kCLOCK_SysPll2Div6Gate = (uint32_t)(&(CCM)->PLL_CTRL[30].PLL_CTRL),
 kCLOCK SysPll2Div8Gate = (uint32 t)(&(CCM)->PLL CTRL[31].PLL CTRL),
 kCLOCK_SysPll2Div10Gate = (uint32_t)(&(CCM)->PLL_CTRL[32].PLL_CTRL),
 kCLOCK SysPll2Div20Gate = (uint32 t)(&(CCM)->PLL CTRL[33].PLL CTRL),
 kCLOCK_SysPll3Gate = (uint32_t)(&(CCM)->PLL_CTRL[34].PLL_CTRL),
 kCLOCK AudioPll1Gate = (uint32 t)(&(CCM)->PLL CTRL[35].PLL CTRL),
 kCLOCK AudioPll2Gate = (uint32 t)(&(CCM)->PLL CTRL[36].PLL CTRL),
 kCLOCK_VideoPll1Gate = (uint32_t)(&(CCM)->PLL_CTRL[37].PLL_CTRL),
 kCLOCK_VideoPll2Gate = (uint32_t)(&(CCM)->PLL_CTRL[38].PLL_CTRL) }
    CCM PLL gate control.
enum clock_gate_value_t {
 kCLOCK\_ClockNotNeeded = 0x0U,
 kCLOCK_ClockNeededRun = 0x1111U,
 kCLOCK ClockNeededRunWait = 0x2222U,
 kCLOCK ClockNeededAll = 0x3333U }
    CCM gate control value.
enum clock_pll_bypass_ctrl_t {
```

```
kCLOCK AudioPll1BypassCtrl,
 kCLOCK_AudioPll2BypassCtrl,
 kCLOCK_VideoPll1BypassCtrl,
 kCLOCK_GpuPLLPwrBypassCtrl,
 kCLOCK_VpuPllPwrBypassCtrl,
 kCLOCK_ArmPllPwrBypassCtrl,
 kCLOCK_SysPll1InternalPll1BypassCtrl,
 kCLOCK_SysPll1InternalPll2BypassCtrl,
 kCLOCK SysPll2InternalPll1BypassCtrl,
 kCLOCK_SysPll2InternalPll2BypassCtrl,
 kCLOCK_SysPll3InternalPll1BypassCtrl,
 kCLOCK_SysPll3InternalPll2BypassCtrl.
 kCLOCK_VideoPll2InternalPll1BypassCtrl,
 kCLOCK VideoPll2InternalPll2BypassCtrl,
 kCLOCK_DramPllInternalPll1BypassCtrl,
 kCLOCK DramPllInternalPll2BypassCtrl }
    PLL control names for PLL bypass.
enum clock_pll_clke_t {
 kCLOCK_AudioPll1Clke,
 kCLOCK_AudioPll2Clke,
 kCLOCK_VideoPll1Clke,
 kCLOCK_GpuPllClke = CCM_ANALOG_TUPLE(GPU_PLL_CFG0, CCM_ANALOG_GPU_P-
 LL CFG0 PLL CLKE SHIFT),
 kCLOCK_VpuPllClke = CCM_ANALOG_TUPLE(VPU_PLL_CFG0, CCM_ANALOG_VPU_P-
 LL CFG0 PLL CLKE SHIFT),
 kCLOCK ArmPllClke = CCM ANALOG TUPLE(ARM PLL CFG0, CCM ANALOG ARM -
```

### Overview

```
PLL CFG0 PLL CLKE SHIFT),
 kCLOCK_SystemPll1Clke,
 kCLOCK_SystemPll1Div2Clke,
 kCLOCK_SystemPll1Div3Clke,
 kCLOCK SystemPll1Div4Clke,
 kCLOCK SystemPll1Div5Clke,
 kCLOCK_SystemPll1Div6Clke,
 kCLOCK_SystemPll1Div8Clke,
 kCLOCK SystemPll1Div10Clke,
 kCLOCK_SystemPll1Div20Clke,
 kCLOCK_SystemPll2Clke,
 kCLOCK SystemPll2Div2Clke,
 kCLOCK_SystemPll2Div3Clke,
 kCLOCK_SystemPll2Div4Clke,
 kCLOCK_SystemPll2Div5Clke,
 kCLOCK_SystemPll2Div6Clke,
 kCLOCK SystemPll2Div8Clke,
 kCLOCK_SystemPll2Div10Clke,
 kCLOCK_SystemPll2Div20Clke,
 kCLOCK SystemPll3Clke,
 kCLOCK_VideoPll2Clke,
 kCLOCK_DramPllClke = CCM_ANALOG_TUPLE(DRAM_PLL_CFG0, CCM_ANALOG_DR-
 AM_PLL_CFG0_PLL_CLKE_SHIFT),
 kCLOCK OSC25MClke = CCM ANALOG TUPLE(OSC MISC CFG, CCM ANALOG OSC-
 MISC CFG OSC 25M CLKE SHIFT),
 kCLOCK_OSC27MClke = CCM_ANALOG_TUPLE(OSC_MISC_CFG, CCM_ANALOG_OSC-
 _MISC_CFG_OSC_27M_CLKE_SHIFT) }
    PLL clock names for clock enable/disable settings.
enum clock_pll_ctrl_t
    ANALOG Power down override control.
enum _osc_mode {
 kOSC_OscMode = 0U,
 kOSC ExtMode = 1U }
    OSC work mode.
• enum osc32_src_t {
 kOSC32\_Src25MDiv800 = 0U,
 kOSC32_SrcRTC }
    OSC 32K input select.
enum _ccm_analog_pll_ref_clk {
 kANALOG_PllRefOsc25M = 0U,
 kANALOG_PllRefOsc27M = 1U,
 kANALOG PllRefOscHdmiPhy27M = 2U,
 kANALOG PllRefClkPN = 3U }
    PLL reference clock select.
```

### **Driver version**

• #define FSL\_CLOCK\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 1)) CLOCK driver version 2.0.1.

## **CCM Root Clock Setting**

- static void CLOCK\_SetRootMux (clock\_root\_control\_t rootClk, uint32\_t mux) Set clock root mux.
- static uint32\_t CLOCK\_GetRootMux (clock\_root\_control\_t rootClk) Get clock root mux.
- static void CLOCK\_EnableRoot (clock\_root\_control\_t rootClk)
- Enable clock root.
- static void CLOCK\_DisableRoot (clock\_root\_control\_t rootClk)
   Disable clock root.
- static bool CLOCK\_IsRootEnabled (clock\_root\_control\_t rootClk) Check whether clock root is enabled.
- void CLOCK\_UpdateRoot (clock\_root\_control\_t ccmRootClk, uint32\_t mux, uint32\_t pre, uint32\_t post)
  - Update clock root in one step, for dynamical clock switching Note: The PRE and POST dividers in this function are the actually divider, software will map it to register value.
- void CLOCK\_SetRootDivider (clock\_root\_control\_t ccmRootClk, uint32\_t pre, uint32\_t post)

  Set root clock divider Note: The PRE and POST dividers in this function are the actually divider, software will map it to register value.
- static uint32\_t CLOCK\_GetRootPreDivider (clock\_root\_control\_t rootClk)
   Get clock root PRE PODF.
- static uint32\_t CLOCK\_GetRootPostDivider (clock\_root\_control\_t rootClk)
   Get clock root POST\_PODF.

# **OSC** setting

- void CLOCK\_InitOSC25M (const osc\_config\_t \*config)
   OSC25M init.
- void CLOCK\_DeinitOSC25M (void)

OSC25M deinit.

• void CLOCK\_InitOSC27M (const osc\_config\_t \*config)

OSC27M init.

• void CLOCK DeinitOSC27M (void)

OSC27M deinit.

static void CLOCK\_SwitchOSC32Src (osc32\_src\_t sel)

switch 32KHZ OSC input

## **CCM Gate Control**

- static void CLOCK\_ControlGate (uint32\_t ccmGate, clock\_gate\_value\_t control) lockrief Set PLL or CCGR gate control
- void CLOCK\_EnableClock (clock\_ip\_name\_t ccmGate)
  - Enable CCGR clock gate and root clock gate for each module User should set specific gate for each module according to the description of the table of system clocks, gating and override in CCM chapter of reference manual.
- void CLOCK\_DisableClock (clock\_ip\_name\_t ccmGate)

#### MCUXpresso SDK API Reference Manual

### Overview

Disable CCGR clock gate for the each module User should set specific gate for each module according to the description of the table of system clocks, gating and override in CCM chapter of reference manual.

## **CCM Analog PLL Operatoin Functions**

- static void CLOCK\_PowerUpPll (CCM\_ANALOG\_Type \*base, clock\_pll\_ctrl\_t pllControl)

  \*Power up PLL.
- static void CLOCK\_PowerDownPll (CCM\_ANALOG\_Type \*base, clock\_pll\_ctrl\_t pllControl) Power down PLL.
- static void CLOCK\_SetPllBypass (CCM\_ANALOG\_Type \*base, clock\_pll\_bypass\_ctrl\_t pll-Control, bool bypass)

PLL bypass setting.

 static bool CLOCK\_IsPIlBypassed (CCM\_ANALOG\_Type \*base, clock\_pll\_bypass\_ctrl\_t pll-Control)

Check if PLL is bypassed.

- static bool CLOCK\_IsPIlLocked (CCM\_ANALOG\_Type \*base, clock\_pll\_ctrl\_t pllControl) Check if PLL clock is locked.
- static void CLOCK\_EnableAnalogClock (CCM\_ANALOG\_Type \*base, clock\_pll\_clke\_t pll-Clock)

Enable PLL clock.

 static void CLOCK\_DisableAnalogClock (CCM\_ANALOG\_Type \*base, clock\_pll\_clke\_t pll-Clock)

Disable PLL clock.

• static void CLOCK\_OverrideAnalogClke (CCM\_ANALOG\_Type \*base, clock\_pll\_clke\_t ov-Clock, bool override)

Override PLL clock output enable.

• static void CLOCK\_OverridePllPd (CCM\_ANALOG\_Type \*base, clock\_pll\_ctrl\_t pdClock, bool override)

Override PLL power down.

void CLOCK\_InitArmPll (const ccm\_analog\_frac\_pll\_config\_t \*config)

Initializes the ANALOG ARM PLL.

• void CLOCK DeinitArmPll (void)

De-initialize the ARM PLL.

• void CLOCK\_InitSysPll1 (const ccm\_analog\_sscg\_pll\_config\_t \*config)

Initializes the ANALOG SYS PLL1.

void CLOCK\_DeinitSysPll1 (void)

De-initialize the System PLL1.

• void CLOCK\_InitSysPll2 (const ccm\_analog\_sscg\_pll\_config\_t \*config)

*Initializes the ANALOG SYS PLL2.* 

• void CLOCK\_DeinitSysPll2 (void)

De-initialize the System PLL2.

- void CLOCK\_InitSysPll3 (const ccm\_analog\_sscg\_pll\_config\_t \*config)
- void CLOCK\_DeinitSysPll3 (void)

*Initializes the ANALOG SYS PLL3.* 

Initializes the ANALOG DDR PLL.

De-initialize the System PLL3.

- void CLOCK\_InitDramPll (const ccm\_analog\_sscg\_pll\_config\_t \*config)
- void CLOCK DeinitDramPll (void)

De-initialize the Dram PLL.

void CLOCK\_InitAudioPll1 (const ccm\_analog\_frac\_pll\_config\_t \*config)

Initializes the ANALOG AUDIO PLL1.

• void CLOCK\_DeinitAudioPll1 (void)

De-initialize the Audio PLL1.

void CLOCK\_InitAudioPll2 (const ccm\_analog\_frac\_pll\_config\_t \*config)

Initializes the ANALOG AUDIO PLL2.

void CLOCK\_DeinitAudioPll2 (void)

De-initialize the Audio PLL2.

• void CLOCK\_InitVideoPll1 (const ccm\_analog\_frac\_pll\_config\_t \*config)

Initializes the ANALOG VIDEO PLL1.

• void CLOCK\_DeinitVideoPll1 (void)

De-initialize the Video PLL1.

void CLOCK\_InitVideoPll2 (const ccm\_analog\_sscg\_pll\_config\_t \*config)

Initializes the ANALOG VIDEO PLL2.

• void CLOCK\_DeinitVideoPll2 (void)

De-initialize the Video PLL2.

void CLOCK\_InitSSCGPll (CCM\_ANALOG\_Type \*base, const ccm\_analog\_sscg\_pll\_config\_t \*config, clock\_pll\_ctrl\_t type)

Initializes the ANALOG SSCG PLL.

• uint32\_t CLOCK\_GetSSCGPllFreq (CCM\_ANALOG\_Type \*base, clock\_pll\_ctrl\_t type, uint32\_t refClkFreq, bool pll1Bypass)

Get the ANALOG SSCG PLL clock frequency.

• void CLOCK\_InitFracPll (CCM\_ANALOG\_Type \*base, const ccm\_analog\_frac\_pll\_config\_t \*config, clock\_pll\_ctrl\_t type)

Initializes the ANALOG Fractional PLL.

uint32\_t CLOCK\_GetFracPllFreq (CCM\_ANALOG\_Type \*base, clock\_pll\_ctrl\_t type, uint32\_t refClkFreq)

Gets the ANALOG Fractional PLL clock frequency.

• uint32\_t CLOCK\_GetPllFreq (clock\_pll\_ctrl\_t pll)

Gets PLL clock frequency.

• uint32 t CLOCK GetPllRefClkFreq (clock pll ctrl t ctrl)

Gets PLL reference clock frequency.

# **CCM Get frequency**

• uint32\_t CLOCK\_GetFreq (clock\_name\_t clockName)

Gets the clock frequency for a specific clock name.

• uint32 t CLOCK GetCoreM4Freq (void)

Get the CCM Cortex M4 core frequency.

• uint32\_t CLOCK\_GetAxiFreq (void)

Get the CCM Axi bus frequency.

• uint32\_t CLOCK\_GetAhbFreq (void)

Get the CCM Ahb bus frequency.

### 5.2 Data Structure Documentation

## 5.2.1 struct osc\_config\_t

#### **Data Fields**

• uint8 t oscMode

MCUXpresso SDK API Reference Manual

### **Data Structure Documentation**

ext or osc modeuint8\_t oscDivosc divider

## 5.2.2 struct ccm analog frac pll config t

Note: all the dividers in this configuration structure are the actually divider, software will map it to register value

### **Data Fields**

• uint8 t refSel

pll reference clock sel

uint8\_t refDiv

A 6bit divider to make sure the REF must be within the range 10MHZ~300MHZ.

uint32\_t fractionDiv

*Inlcude fraction divider(divider:1:2*<sup>24</sup>) *output clock range is 2000MHZ-4000MHZ.* 

• uint8\_t outDiv

output clock divide, output clock range is 30MHZ to 2000MHZ, must be a even value

## 5.2.3 struct ccm\_analog\_sscg\_pll\_config\_t

Note: all the dividers in this configuration structure are the actually divider, software will map it to register value

### **Data Fields**

• uint8\_t refSel

pll reference clock sel

• uint8\_t refDiv1

A 3bit divider to make sure the REF must be within the range 25MHZ~235MHZ ,post\_divide REF must be within the range 25MHZ~54MHZ.

uint8\_t refDiv2

A 6bit divider to make sure the post\_divide REF must be within the range 54MHZ~75MHZ.

• uint32 t loopDivider1

A 6bit internal PLL1 feedback clock divider, output clock range must be within the range 1600MHZ-2400-MHZ.

uint32\_t loopDivider2

A 6bit internal PLL2 feedback clock divider, output clock range must be within the range 1200MHZ-2400-MHZ.

uint8 t outDiv

A 6bit output clock divide, output clock range is 20MHZ to 1200MHZ.

25

### 5.3 Macro Definition Documentation

## 5.3.1 #define FSL\_CLOCK\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 1))

## 5.3.2 #define ECSPI\_CLOCKS

Value:

```
{
     kCLOCK_IpInvalid, kCLOCK_Ecspi1, kCLOCK_Ecspi2,
     kCLOCK_Ecspi3, \
}
```

## 5.3.3 #define GPIO CLOCKS

Value:

```
{
     kCLOCK_IpInvalid, kCLOCK_Gpio1, kCLOCK_Gpio2,
     kCLOCK_Gpio3, kCLOCK_Gpio4, kCLOCK_Gpio5, \
}
```

# 5.3.4 #define GPT\_CLOCKS

Value:

```
{
    kCLOCK_IpInvalid, kCLOCK_Gpt1, kCLOCK_Gpt2,
    kCLOCK_Gpt3, kCLOCK_Gpt4, kCLOCK_Gpt5,
    kCLOCK_Gpt6, \
}
```

## 5.3.5 #define I2C\_CLOCKS

Value:

```
{
    kCLOCK_IpInvalid, kCLOCK_I2c1, kCLOCK_I2c2,
    kCLOCK_I2c3, kCLOCK_I2c4, \
```

### **Macro Definition Documentation**

## 5.3.6 #define IOMUX\_CLOCKS

```
Value:
```

```
{
     kCLOCK_IpInvalid, kCLOCK_Iomuxc0, kCLOCK_Iomuxc1, kCLOCK_Iomuxc2, kCLOCK_Iomuxc3, kCLOCK_Iomuxc4, \
}
```

## 5.3.7 #define PWM\_CLOCKS

### Value:

```
{
    kCLOCK_IpInvalid, kCLOCK_Pwm1, kCLOCK_Pwm2,
    kCLOCK_Pwm3, kCLOCK_Pwm4, \
```

## 5.3.8 #define RDC\_CLOCKS

### Value:

```
{ kCLOCK_Rdc, \
```

## 5.3.9 #define SAI\_CLOCKS

### Value:

```
{
    kCLOCK_IpInvalid, kCLOCK_Sai1, kCLOCK_Sai2,
    kCLOCK_Sai3, kCLOCK_Sai4, kCLOCK_Sai5,
    kCLOCK_Sai6, \
}
```

# 5.3.10 #define RDC\_SEMA42\_CLOCKS

### Value:

```
{
      kCLOCK_IpInvalid, kCLOCK_Sema42_1, kCLOCK_Sema42_2 \
}
```

### MCUXpresso SDK API Reference Manual

## 5.3.11 #define UART CLOCKS

## Value:

```
{
    kCLOCK_IpInvalid, kCLOCK_Uart1, kCLOCK_Uart2,
    kCLOCK_Uart3, kCLOCK_Uart4, \
}
```

# 5.3.12 #define USDHC\_CLOCKS

### Value:

```
{
      kCLOCK_IpInvalid, kCLOCK_Usdhc1, kCLOCK_Usdhc2 \
}
```

## 5.3.13 #define WDOG\_CLOCKS

### Value:

```
{
     kCLOCK_IpInvalid, kCLOCK_Wdog1, kCLOCK_Wdog2,
     kCLOCK_Wdog3 \
}
```

# 5.3.14 #define TMU\_CLOCKS

### Value:

```
{
      kCLOCK_TempSensor, \
}
```

# 5.3.15 #define SDMA\_CLOCKS

### Value:

## MCUXpresso SDK API Reference Manual

## 5.3.16 #define MU\_CLOCKS

### Value:

```
{
          kCLOCK_Mu \
}
```

## 5.3.17 #define QSPI CLOCKS

### Value:

```
{
            kCLOCK_Qspi \
}
```

- 5.3.18 #define kCLOCK CoreSysClk kCLOCK\_CoreM4Clk
- 5.3.19 #define CLOCK\_GetCoreSysClkFreq CLOCK\_GetCoreM4Freq
- 5.4 Enumeration Type Documentation
- 5.4.1 enum clock\_name\_t

### Enumerator

```
kCLOCK_CoreM4Clk ARM M4 Core clock.
kCLOCK_AxiClk Main AXI bus clock.
kCLOCK_AhbClk AHB bus clock.
kCLOCK_IpgClk IPG bus clock.
```

# 5.4.2 enum clock\_ip\_name\_t

### Enumerator

```
kCLOCK_Debug
kCLOCK_Dram
DRAM Clock Gate.
kCLOCK_Ecspi1
ECSPI1 Clock Gate.
kCLOCK_Ecspi2
ECSPI2 Clock Gate.
kCLOCK_Ecspi3
ECSPI3 Clock Gate.
kCLOCK_Gpio1
GPIO1 Clock Gate.
kCLOCK_Gpio2
GPIO2 Clock Gate.
```

- kCLOCK Gpio3 GPIO3 Clock Gate.
- kCLOCK\_Gpio4 GPIO4 Clock Gate.
- kCLOCK Gpio5 GPIO5 Clock Gate.
- kCLOCK\_Gpt1 GPT1 Clock Gate.
- kCLOCK Gpt2 GPT2 Clock Gate.
- kCLOCK Gpt3 GPT3 Clock Gate.
- kCLOCK\_Gpt4 GPT4 Clock Gate.
- kCLOCK\_Gpt5 GPT5 Clock Gate.
- kCLOCK Gpt6 GPT6 Clock Gate.
- kCLOCK 12c1 I2C1 Clock Gate.
- kCLOCK 12c2 I2C2 Clock Gate.
- kCLOCK 12c3 I2C3 Clock Gate.
- kCLOCK 12c4 I2C4 Clock Gate.
- kCLOCK Iomux0 IOMUX Clock Gate.
- kCLOCK\_Iomux1 IOMUX Clock Gate.
- kCLOCK\_Iomux2 IOMUX Clock Gate.
- kCLOCK\_Iomux3 IOMUX Clock Gate.
- kCLOCK Iomux4 IOMUX Clock Gate.
- kCLOCK\_M4 M4 Clock Gate.
- kCLOCK Mu MU Clock Gate.
- kCLOCK\_Ocram OCRAM Clock Gate.
- kCLOCK OcramS OCRAM S Clock Gate.
- kCLOCK\_Pwm1 PWM1 Clock Gate.
- kCLOCK Pwm2 PWM2 Clock Gate.
- kCLOCK Pwm3 PWM3 Clock Gate.
- kCLOCK\_Pwm4 PWM4 Clock Gate.
- kCLOCK\_Ospi QSPI Clock Gate.
- kCLOCK Rdc RDC Clock Gate.
- kCLOCK Sail SAI1 Clock Gate.
- kCLOCK Sai2 SAI2 Clock Gate.
- kCLOCK\_Sai3 SAI3 Clock Gate.
- kCLOCK Sai4 SAI4 Clock Gate.
- kCLOCK Sai5 SAI5 Clock Gate.
- kCLOCK\_Sai6 SAI6 Clock Gate.
- kCLOCK\_Sdma1 SDMA1 Clock Gate.
- kCLOCK Sdma2 SDMA2 Clock Gate.
- kCLOCK\_Sec\_Debug SEC\_DEBUG Clock Gate.
- kCLOCK\_Sema42\_1 RDC SEMA42 Clock Gate.
- kCLOCK Sema42 2 RDC SEMA42 Clock Gate.
- kCLOCK\_Sim\_display SIM\_Display Clock Gate.
- kCLOCK Sim m SIM M Clock Gate.
- kCLOCK\_Sim\_main SIM\_MAIN Clock Gate.
- kCLOCK Sim s SIM S Clock Gate.
- kCLOCK Sim wakeup SIM WAKEUP Clock Gate.
- kCLOCK\_Uart1 UART1 Clock Gate.

### MCUXpresso SDK API Reference Manual

```
kCLOCK_Uart2 UART2 Clock Gate.
kCLOCK_Uart3 UART3 Clock Gate.
kCLOCK_Uart4 UART4 Clock Gate.
kCLOCK_Wdog1 WDOG1 Clock Gate.
kCLOCK_Wdog2 WDOG2 Clock Gate.
kCLOCK_Wdog3 WDOG3 Clock Gate.
kCLOCK_TempSensor TempSensor Clock Gate.
```

## 5.4.3 enum clock\_root\_control\_t

#### Enumerator

```
kCLOCK RootM4 ARM Cortex-M4 Clock control name.
kCLOCK RootAxi AXI Clock control name.
kCLOCK RootNoc NOC Clock control name.
kCLOCK_RootAhb AHB Clock control name.
kCLOCK Rootlpg IPG Clock control name.
kCLOCK RootDramAlt DRAM ALT Clock control name.
kCLOCK RootSai1 SAI1 Clock control name.
kCLOCK_RootSai2 SAI2 Clock control name.
kCLOCK RootSai3 SAI3 Clock control name.
kCLOCK_RootSai4 SAI4 Clock control name.
kCLOCK RootSai5 SAI5 Clock control name.
kCLOCK_RootSai6 SAI6 Clock control name.
kCLOCK_RootQspi QSPI Clock control name.
kCLOCK_RootI2c1 I2C1 Clock control name.
kCLOCK RootI2c2 I2C2 Clock control name.
kCLOCK RootI2c3 I2C3 Clock control name.
kCLOCK RootI2c4 I2C4 Clock control name.
kCLOCK_RootUart1 UART1 Clock control name.
kCLOCK_RootUart2 UART2 Clock control name.
kCLOCK RootUart3 UART3 Clock control name.
kCLOCK RootUart4 UART4 Clock control name.
kCLOCK_RootEcspi1 ECSPI1 Clock control name.
kCLOCK_RootEcspi2 ECSPI2 Clock control name.
kCLOCK_RootEcspi3 ECSPI3 Clock control name.
kCLOCK RootPwm1 PWM1 Clock control name.
kCLOCK_RootPwm2 PWM2 Clock control name.
kCLOCK_RootPwm3 PWM3 Clock control name.
kCLOCK RootPwm4 PWM4 Clock control name.
kCLOCK_RootGpt1 GPT1 Clock control name.
kCLOCK_RootGpt2 GPT2 Clock control name.
kCLOCK_RootGpt3 GPT3 Clock control name.
kCLOCK RootGpt4 GPT4 Clock control name.
```

### MCUXpresso SDK API Reference Manual

kCLOCK\_RootGpt5 GPT5 Clock control name.kCLOCK\_RootGpt6 GPT6 Clock control name.kCLOCK\_RootWdog WDOG Clock control name.

## 5.4.4 enum clock rootmux m4 clk sel t

### Enumerator

kCLOCK M4RootmuxOsc25m ARM Cortex-M4 Clock from OSC 25M.

kCLOCK\_M4RootmuxSysPll2Div5 ARM Cortex-M4 Clock from SYSTEM PLL2 divided by 5.

kCLOCK\_M4RootmuxSysPll2Div4 ARM Cortex-M4 Clock from SYSTEM PLL2 divided by 4.

kCLOCK M4RootmuxSysPll1Div3 ARM Cortex-M4 Clock from SYSTEM PLL1 divided by 3.

kCLOCK M4RootmuxSysPll1 ARM Cortex-M4 Clock from SYSTEM PLL1.

kCLOCK\_M4RootmuxAudioPll1 ARM Cortex-M4 Clock from AUDIO PLL1.

kCLOCK M4RootmuxVideoPll1 ARM Cortex-M4 Clock from VIDEO PLL1.

kCLOCK\_M4RootmuxSysPll3 ARM Cortex-M4 Clock from SYSTEM PLL3.

## 5.4.5 enum clock rootmux axi clk sel t

#### Enumerator

kCLOCK AxiRootmuxOsc25m ARM AXI Clock from OSC 25M.

kCLOCK\_AxiRootmuxSysPll2Div3 ARM AXI Clock from SYSTEM PLL2 divided by 3.

kCLOCK\_AxiRootmuxSysPll1 ARM AXI Clock from SYSTEM PLL1.

kCLOCK\_AxiRootmuxSysPll2Div4 ARM AXI Clock from SYSTEM PLL2 divided by 4.

kCLOCK\_AxiRootmuxSysPll2 ARM AXI Clock from SYSTEM PLL2.

kCLOCK AxiRootmuxAudioPll1 ARM AXI Clock from AUDIO PLL1.

kCLOCK\_AxiRootmuxVideoPll1 ARM AXI Clock from VIDEO PLL1.

kCLOCK\_AxiRootmuxSysPll1Div8 ARM AXI Clock from SYSTEM PLL1 divided by 8.

# 5.4.6 enum clock\_rootmux\_ahb\_clk\_sel\_t

### Enumerator

kCLOCK\_AhbRootmuxOsc25m ARM AHB Clock from OSC 25M.

kCLOCK AhbRootmuxSysPll1Div6 ARM AHB Clock from SYSTEM PLL1 divided by 6.

kCLOCK\_AhbRootmuxSysPll1 ARM AHB Clock from SYSTEM PLL1.

kCLOCK\_AhbRootmuxSysPll1Div2 ARM AHB Clock from SYSTEM PLL1 divided by 2.

kCLOCK\_AhbRootmuxSysPll2Div8 ARM AHB Clock from SYSTEM PLL2 divided by 8.

kCLOCK\_AhbRootmuxSysPll3 ARM AHB Clock from SYSTEM PLL3.

kCLOCK AhbRootmuxAudioPll1 ARM AHB Clock from AUDIO PLL1.

kCLOCK\_AhbRootmuxVideoPll1 ARM AHB Clock from VIDEO PLL1.

## MCUXpresso SDK API Reference Manual

## 5.4.7 enum clock\_rootmux\_qspi\_clk\_sel\_t

### Enumerator

kCLOCK\_QspiRootmuxOsc25m ARM QSPI Clock from OSC 25M.

kCLOCK\_QspiRootmuxSysPll1Div2 ARM QSPI Clock from SYSTEM PLL1 divided by 2.

kCLOCK\_QspiRootmuxSysPll1 ARM QSPI Clock from SYSTEM PLL1.

kCLOCK\_QspiRootmuxSysPll2Div2 ARM QSPI Clock from SYSTEM PLL2 divided by 2.

kCLOCK\_OspiRootmuxAudioPll2 ARM QSPI Clock from AUDIO PLL2.

kCLOCK\_QspiRootmuxSysPll1Div3 ARM QSPI Clock from SYSTEM PLL1 divided by 3.

kCLOCK\_QspiRootmuxSysPll3 ARM QSPI Clock from SYSTEM PLL3.

kCLOCK\_QspiRootmuxSysPll1Div8 ARM QSPI Clock from SYSTEM PLL1 divided by 8.

## 5.4.8 enum clock\_rootmux\_ecspi\_clk\_sel\_t

### Enumerator

kCLOCK\_EcspiRootmuxOsc25m ECSPI Clock from OSC 25M.

kCLOCK\_EcspiRootmuxSysPll2Div5 ECSPI Clock from SYSTEM PLL2 divided by 5.

kCLOCK\_EcspiRootmuxSysPll1Div20 ECSPI Clock from SYSTEM PLL1 divided by 20.

kCLOCK\_EcspiRootmuxSysPll1Div5 ECSPI Clock from SYSTEM PLL1 divided by 5.

kCLOCK EcspiRootmuxSysPll1 ECSPI Clock from SYSTEM PLL1.

kCLOCK EcspiRootmuxSvsPll3 ECSPI Clock from SYSTEM PLL3.

kCLOCK\_EcspiRootmuxSysPll2Div4 ECSPI Clock from SYSTEM PLL2 divided by 4.

kCLOCK EcspiRootmuxAudioPll2 ECSPI Clock from AUDIO PLL2.

## 5.4.9 enum clock rootmux i2c clk sel t

#### Enumerator

kCLOCK I2cRootmuxOsc25m I2C Clock from OSC 25M.

kCLOCK\_I2cRootmuxSysPll1Div5 I2C Clock from SYSTEM PLL1 divided by 5.

kCLOCK\_I2cRootmuxSysPll2Div20 I2C Clock from SYSTEM PLL2 divided by 20.

kCLOCK I2cRootmuxSysPll3 I2C Clock from SYSTEM PLL3.

kCLOCK\_I2cRootmuxSysPll1Div6 I2C Clock from SYSTEM PLL1 divided by 6.

## 5.4.10 enum clock rootmux uart clk sel t

### Enumerator

kCLOCK UartRootmuxOsc25m UART Clock from OSC 25M.

kCLOCK\_UartRootmuxSysPll1Div10 UART Clock from SYSTEM PLL1 divided by 10.

kCLOCK\_UartRootmuxSysPll2Div5 UART Clock from SYSTEM PLL2 divided by 5.

kCLOCK\_UartRootmuxSysPll2Div10 UART Clock from SYSTEM PLL2 divided by 10.

kCLOCK\_UartRootmuxSysPll3 UART Clock from SYSTEM PLL3.

kCLOCK\_UartRootmuxExtClk2 UART Clock from External Clock 2.

kCLOCK\_UartRootmuxExtClk34 UART Clock from External Clock 3, External Clock 4.

kCLOCK UartRootmuxAudioPll2 UART Clock from Audio PLL2.

## 5.4.11 enum clock\_rootmux\_gpt\_t

### Enumerator

kCLOCK\_GptRootmuxOsc25m GPT Clock from OSC 25M.

kCLOCK GptRootmuxSystemPll2Div10 GPT Clock from SYSTEM PLL2 divided by 10.

kCLOCK\_GptRootmuxSysPll1Div2 GPT Clock from SYSTEM PLL1 divided by 2.

kCLOCK\_GptRootmuxSysPll1Div20 GPT Clock from SYSTEM PLL1 divided by 20.

kCLOCK GptRootmuxVideoPll1 GPT Clock from VIDEO PLL1.

kCLOCK\_GptRootmuxSystemPll1Div10 GPT Clock from SYSTEM PLL1 divided by 10.

kCLOCK\_GptRootmuxAudioPll1 GPT Clock from AUDIO PLL1.

kCLOCK\_GptRootmuxExtClk123 GPT Clock from External Clock1, External Clock2, External Clock3.

# 5.4.12 enum clock\_rootmux\_wdog\_clk\_sel\_t

### Enumerator

kCLOCK\_WdogRootmuxOsc25m WDOG Clock from OSC 25M.

kCLOCK\_WdogRootmuxSysPll1Div6 WDOG Clock from SYSTEM PLL1 divided by 6.

kCLOCK WdogRootmuxSysPll1Div5 WDOG Clock from SYSTEM PLL1 divided by 5.

kCLOCK\_WdogRootmuxVpuPll WDOG Clock from VPU DLL.

kCLOCK\_WdogRootmuxSystemPll2Div8 WDOG Clock from SYSTEM PLL2 divided by 8.

kCLOCK\_WdogRootmuxSystemPll3 WDOG Clock from SYSTEM PLL3.

kCLOCK\_WdogRootmuxSystemPll1Div10 WDOG Clock from SYSTEM PLL1 divided by 10.

kCLOCK\_WdogRootmuxSystemPll2Div6 WDOG Clock from SYSTEM PLL2 divided by 6.

## 5.4.13 enum clock\_rootmux\_Pwm\_clk\_sel\_t

### Enumerator

kCLOCK PwmRootmuxOsc25m PWM Clock from OSC 25M.

kCLOCK\_PwmRootmuxSysPll2Div10 PWM Clock from SYSTEM PLL2 divided by 10.

kCLOCK\_PwmRootmuxSysPll1Div5 PWM Clock from SYSTEM PLL1 divided by 5.

kCLOCK\_PwmRootmuxSysPll1Div20 PWM Clock from SYSTEM PLL1 divided by 20.

kCLOCK\_PwmRootmuxSystemPll3 PWM Clock from SYSTEM PLL3.

kCLOCK\_PwmRootmuxExtClk12 PWM Clock from External Clock1, External Clock2.

kCLOCK\_PwmRootmuxSystemPll1Div10 PWM Clock from SYSTEM PLL1 divided by 10.

kCLOCK PwmRootmuxVideoPll1 PWM Clock from VIDEO PLL1.

## 5.4.14 enum clock\_rootmux\_sai\_clk\_sel\_t

#### Enumerator

kCLOCK\_SaiRootmuxOsc25m SAI Clock from OSC 25M.

kCLOCK SaiRootmuxAudioPll1 SAI Clock from AUDIO PLL1.

kCLOCK SaiRootmuxAudioPll2 SAI Clock from AUDIO PLL2.

kCLOCK SaiRootmuxVideoPll1 SAI Clock from VIDEO PLL1.

kCLOCK\_SaiRootmuxSysPll1Div6 SAI Clock from SYSTEM PLL1 divided by 6.

kCLOCK\_SaiRootmuxOsc27m SAI Clock from OSC 27M.

kCLOCK\_SaiRootmuxExtClk123 SAI Clock from External Clock1, External Clock2, External Clock3.

kCLOCK\_SaiRootmuxExtClk234 SAI Clock from External Clock2, External Clock3, External Clock4.

# 5.4.15 enum clock\_rootmux\_noc\_clk\_sel\_t

### Enumerator

kCLOCK NocRootmuxOsc25m NOC Clock from OSC 25M.

kCLOCK\_NocRootmuxSysPll1 NOC Clock from SYSTEM PLL1.

kCLOCK\_NocRootmuxSysPll3 NOC Clock from SYSTEM PLL3.

kCLOCK\_NocRootmuxSysPll2 NOC Clock from SYSTEM PLL2.

kCLOCK\_NocRootmuxSysPll2Div2 NOC Clock from SYSTEM PLL2 divided by 2.

kCLOCK NocRootmuxAudioPll1 NOC Clock from AUDIO PLL1.

kCLOCK\_NocRootmuxVideoPll1 NOC Clock from VIDEO PLL1.

kCLOCK\_NocRootmuxAudioPll2 NOC Clock from AUDIO PLL2.

35

## 5.4.16 enum clock pll gate t

### Enumerator

```
kCLOCK ArmPllGate ARM PLL Gate.
kCLOCK GpuPllGate GPU PLL Gate.
kCLOCK_VpuPllGate VPU PLL Gate.
kCLOCK DramPllGate DRAM PLL1 Gate.
kCLOCK_SysPll1Gate SYSTEM PLL1 Gate.
kCLOCK SysPll1Div2Gate SYSTEM PLL1 Div2 Gate.
kCLOCK_SysPll1Div3Gate SYSTEM PLL1 Div3 Gate.
kCLOCK_SysPll1Div4Gate SYSTEM PLL1 Div4 Gate.
kCLOCK_SysPll1Div5Gate SYSTEM PLL1 Div5 Gate.
kCLOCK SysPll1Div6Gate SYSTEM PLL1 Div6 Gate.
kCLOCK_SysPll1Div8Gate SYSTEM PLL1 Div8 Gate.
kCLOCK_SysPll1Div10Gate SYSTEM PLL1 Div10 Gate.
kCLOCK_SysPll1Div20Gate SYSTEM PLL1 Div20 Gate.
kCLOCK SysPll2Gate SYSTEM PLL2 Gate.
kCLOCK SysPll2Div2Gate SYSTEM PLL2 Div2 Gate.
kCLOCK_SysPll2Div3Gate SYSTEM PLL2 Div3 Gate.
kCLOCK SysPll2Div4Gate SYSTEM PLL2 Div4 Gate.
kCLOCK SysPll2Div5Gate SYSTEM PLL2 Div5 Gate.
kCLOCK_SysPll2Div6Gate SYSTEM PLL2 Div6 Gate.
kCLOCK_SysPll2Div8Gate SYSTEM PLL2 Div8 Gate.
kCLOCK_SysPll2Div10Gate SYSTEM PLL2 Div10 Gate.
kCLOCK SysPll2Div20Gate SYSTEM PLL2 Div20 Gate.
kCLOCK SysPll3Gate SYSTEM PLL3 Gate.
kCLOCK_AudioPll1Gate AUDIO PLL1 Gate.
kCLOCK AudioPll2Gate AUDIO PLL2 Gate.
kCLOCK VideoPll1Gate VIDEO PLL1 Gate.
kCLOCK_VideoPll2Gate VIDEO PLL2 Gate.
```

# 5.4.17 enum clock\_gate\_value\_t

### Enumerator

```
kCLOCK_ClockNotNeeded Clock always disabled.
kCLOCK ClockNeededRun Clock enabled when CPU is running.
kCLOCK_ClockNeededRunWait Clock enabled when CPU is running or in WAIT mode.
kCLOCK_ClockNeededAll Clock always enabled.
```

MCUXpresso SDK API Reference Manual

## 5.4.18 enum clock\_pll\_bypass\_ctrl\_t

These constants define the PLL control names for PLL bypass.

- 0:15: REG offset to CCM\_ANALOG\_BASE in bytes.
- 16:20: bypass bit shift.

### Enumerator

kCLOCK\_VideoPll1BypassCtrl CCM Video Pll1 bypass Control.

kCLOCK\_GpuPLLPwrBypassCtrl CCM Gpu PLL bypass Control.

kCLOCK\_VpuPllPwrBypassCtrl CCM Vpu PLL bypass Control.

kCLOCK\_ArmPllPwrBypassCtrl CCM Arm PLL bypass Control.

kCLOCK SysPll1InternalPll1BypassCtrl CCM System PLL1 internal pll1 bypass Control.

kCLOCK\_SysPll1InternalPll2BypassCtrl CCM System PLL1 internal pll2 bypass Control.

kCLOCK\_SysPll2InternalPll1BypassCtrl CCM Analog System PLL1 internal pll1 bypass Control.

kCLOCK\_SysPll3InternalPll1BypassCtrl CCM Analog VIDEO PLL bypass Control.

kCLOCK VideoPll2InternalPll2BypassCtrl CCM Analog 480M PLL bypass Control.

kCLOCK\_DramPllInternalPll1BypassCtrl CCM Analog 480M PLL bypass Control.

# 5.4.19 enum clock\_pll\_clke\_t

These constants define the PLL clock names for PLL clock enable/disable operations.

- 0:15: REG offset to CCM ANALOG BASE in bytes.
- 16:20: Clock enable bit shift.

#### Enumerator

kCLOCK AudioPll1Clke Audio pll1 clke.

kCLOCK\_AudioPll2Clke Audio pll2 clke.

*kCLOCK\_VideoPll1Clke* Video pll1 clke.

kCLOCK\_GpuPllClke Gpu pll clke.

kCLOCK\_VpuPllClke Vpu pll clke.

kCLOCK\_ArmPllClke Arm pll clke.

kCLOCK\_SystemPll1Clke System pll1 clke.

kCLOCK\_SystemPll1Div2Clke System pll1 Div2 clke.

### MCUXpresso SDK API Reference Manual

kCLOCK\_SystemPll1Div3Clke System pll1 Div3 clke. kCLOCK\_SystemPll1Div4Clke System pll1 Div4 clke. kCLOCK SystemPll1Div5Clke System pll1 Div5 clke. kCLOCK\_SystemPll1Div6Clke System pll1 Div6 clke. kCLOCK SystemPll1Div8Clke System pll1 Div8 clke. kCLOCK SystemPll1Div10Clke System pll1 Div10 clke. kCLOCK\_SystemPll1Div20Clke System pll1 Div20 clke. kCLOCK\_SystemPll2Clke System pll2 clke. kCLOCK SystemPll2Div2Clke System pll2 Div2 clke. kCLOCK\_SystemPll2Div3Clke System pll2 Div3 clke. kCLOCK\_SystemPll2Div4Clke System pll2 Div4 clke. kCLOCK SystemPll2Div5Clke System pll2 Div5 clke. kCLOCK\_SystemPll2Div6Clke System pll2 Div6 clke. kCLOCK SystemPll2Div8Clke System pll2 Div8 clke. kCLOCK\_SystemPll2Div10Clke System pll2 Div10 clke. kCLOCK\_SystemPll2Div20Clke System pll2 Div20 clke. kCLOCK SystemPll3Clke System pll3 clke. kCLOCK\_VideoPll2Clke Video pll2 clke. kCLOCK\_DramPllClke Dram pll clke. kCLOCK OSC25MClke OSC25M clke. kCLOCK\_OSC27MClke OSC27M clke.

## 5.4.20 enum \_osc\_mode

### Enumerator

kOSC\_OscMode OSC oscillator mode.kOSC ExtMode OSC external mode.

## 5.4.21 enum osc32\_src\_t

### Enumerator

kOSC32\_Src25MDiv800 source from 25M divide 800kOSC32\_SrcRTC source from RTC

# 5.4.22 enum \_ccm\_analog\_pll\_ref\_clk

#### Enumerator

kANALOG\_PllRefOsc25M reference OSC 25M

### MCUXpresso SDK API Reference Manual

kANALOG\_PllRefOsc27M reference OSC 27M kANALOG\_PllRefOscHdmiPhy27M reference HDMI PHY 27M kANALOG\_PllRefClkPN reference CLK\_P\_N

### 5.5 Function Documentation

# 5.5.1 static void CLOCK\_SetRootMux ( clock\_root\_control\_t rootClk, uint32\_t mux ) [inline], [static]

User maybe need to set more than one mux ROOT according to the clock tree description in the reference manual.

#### **Parameters**

| rootClk | Root clock control (see clock_root_control_t enumeration). |
|---------|------------------------------------------------------------|
| mux     | Root mux value (see _ccm_rootmux_xxx enumeration).         |

# 5.5.2 static uint32\_t CLOCK\_GetRootMux ( clock\_root\_control\_t rootClk ) [inline], [static]

In order to get the clock source of root, user maybe need to get more than one ROOT's mux value to obtain the final clock source of root.

### **Parameters**

| rootClk | Root clock control (see clock_root_control_t enumeration). |
|---------|------------------------------------------------------------|
|---------|------------------------------------------------------------|

### Returns

Root mux value (see \_ccm\_rootmux\_xxx enumeration).

# 

Parameters

39

| base    | CCM base pointer.                                         |
|---------|-----------------------------------------------------------|
| rootClk | Root clock control (see clock_root_control_t enumeration) |

# 

### **Parameters**

| base    | CCM base pointer.                                   |
|---------|-----------------------------------------------------|
| rootClk | Root control (see clock_root_control_t enumeration) |

# 5.5.5 static bool CLOCK\_IsRootEnabled ( clock\_root\_control\_t rootClk ) [inline], [static]

### **Parameters**

| base    | CCM base pointer.                                   |
|---------|-----------------------------------------------------|
| rootClk | Root control (see clock_root_control_t enumeration) |

### Returns

CCM root enabled or not.

- true: Clock root is enabled.
- false: Clock root is disabled.

# 5.5.6 void CLOCK\_UpdateRoot ( clock\_root\_control\_t ccmRootClk, uint32\_t mux, uint32\_t pre, uint32\_t post )

### **Parameters**

| ccmRootClk | Root control (see clock_root_control_t enumeration) |
|------------|-----------------------------------------------------|
| root       | mux value (see _ccm_rootmux_xxx enumeration)        |

| pre  | Pre divider value (0-7, divider=n+1)   |
|------|----------------------------------------|
| post | Post divider value (0-63, divider=n+1) |

# 5.5.7 void CLOCK\_SetRootDivider ( clock\_root\_control\_t ccmRootClk, uint32\_t pre, uint32\_t post )

### **Parameters**

| ccmRootClk | Root control (see clock_root_control_t enumeration) |
|------------|-----------------------------------------------------|
| pre        | Pre divider value (1-8)                             |
| post       | Post divider value (1-64)                           |

# 5.5.8 static uint32\_t CLOCK\_GetRootPreDivider ( clock\_root\_control\_t rootClk ) [inline], [static]

In order to get the clock source of root, user maybe need to get more than one ROOT's mux value to obtain the final clock source of root.

### Parameters

| rootClk Root clock name (see clock_root_control_t enumeration). |
|-----------------------------------------------------------------|
|-----------------------------------------------------------------|

### Returns

Root Pre divider value.

# 5.5.9 static uint32\_t CLOCK\_GetRootPostDivider ( clock\_root\_control\_t rootClk ) [inline], [static]

In order to get the clock source of root, user maybe need to get more than one ROOT's mux value to obtain the final clock source of root.

Parameters

rootClk | Root clock name (see clock\_root\_control\_t enumeration).

Returns

Root Post divider value.

## 5.5.10 void CLOCK\_InitOSC25M ( const osc\_config\_t \* config )

**Parameters** 

config osc configuration

- 5.5.11 void CLOCK\_DeinitOSC25M (void)
- 5.5.12 void CLOCK\_InitOSC27M (  $const osc\_config\_t * config$  )
- 5.5.13 void CLOCK DeinitOSC27M (void)

**Parameters** 

config osc configuration

# 5.5.14 static void CLOCK\_SwitchOSC32Src ( osc32\_src\_t sel ) [inline], [static]

**Parameters** 

sel OSC32 input clock select

# 5.5.15 static void CLOCK\_ControlGate ( uint32\_t ccmGate, clock\_gate\_value\_t control ) [inline], [static]

base CCM base pointer.

### **Parameters**

| ccmGate | Gate control (see clock_pll_gate_t and clock_ip_name_t enumeration) |
|---------|---------------------------------------------------------------------|
| control | Gate control value (see clock_gate_value_t)                         |

## 5.5.16 void CLOCK\_EnableClock ( clock\_ip\_name\_t ccmGate )

Take care of that one module may need to set more than one clock gate.

### **Parameters**

| ccmGate | Gate control for each module (see clock_ip_name_t enumeration). |
|---------|-----------------------------------------------------------------|
|---------|-----------------------------------------------------------------|

# 5.5.17 void CLOCK\_DisableClock ( clock\_ip\_name\_t ccmGate )

Take care of that one module may need to set more than one clock gate.

### **Parameters**

| ccmGate | Gate control for each module (see clock_ip_name_t enumeration). |  |
|---------|-----------------------------------------------------------------|--|
|---------|-----------------------------------------------------------------|--|

# 5.5.18 static void CLOCK\_PowerUpPII ( CCM\_ANALOG\_Type \* base, clock\_pll\_ctrl\_t pllControl ) [inline], [static]

#### **Parameters**

| base       | CCM_ANALOG base pointer.                            |
|------------|-----------------------------------------------------|
| pllControl | PLL control name (see clock_pll_ctrl_t enumeration) |

# 5.5.19 static void CLOCK\_PowerDownPII ( CCM\_ANALOG\_Type \* base, clock\_pll\_ctrl\_t pllControl ) [inline], [static]

Parameters

43

| base       | CCM_ANALOG base pointer.                            |
|------------|-----------------------------------------------------|
| pllControl | PLL control name (see clock_pll_ctrl_t enumeration) |

# 5.5.20 static void CLOCK\_SetPIIBypass ( CCM\_ANALOG\_Type \* base, clock\_pll\_bypass\_ctrl\_t pllControl, bool bypass ) [inline], [static]

### **Parameters**

| base       | CCM_ANALOG base pointer.                                                  |
|------------|---------------------------------------------------------------------------|
| pllControl | PLL control name (see ccm_analog_pll_control_t enumeration)               |
| bypass     | Bypass the PLL.  • true: Bypass the PLL.  • false: Do not bypass the PLL. |

# 5.5.21 static bool CLOCK\_IsPIIBypassed ( CCM\_ANALOG\_Type \* base, clock\_pll\_bypass\_ctrl\_t pllControl ) [inline], [static]

### **Parameters**

| base       | CCM_ANALOG base pointer.                                    |
|------------|-------------------------------------------------------------|
| pllControl | PLL control name (see ccm_analog_pll_control_t enumeration) |

### Returns

## PLL bypass status.

- true: The PLL is bypassed.
- false: The PLL is not bypassed.

# 5.5.22 static bool CLOCK\_IsPIILocked ( CCM\_ANALOG\_Type \* base, clock\_pll\_ctrl\_t pllControl ) [inline], [static]

### **Parameters**

| base       | CCM_ANALOG base pointer.                            |
|------------|-----------------------------------------------------|
| pllControl | PLL control name (see clock_pll_ctrl_t enumeration) |

### Returns

### PLL lock status.

- true: The PLL clock is locked.
- false: The PLL clock is not locked.

# 5.5.23 static void CLOCK\_EnableAnalogClock ( CCM\_ANALOG\_Type \* base, clock\_pll\_clke\_t pllClock ) [inline], [static]

### **Parameters**

| base     | CCM_ANALOG base pointer.                                |
|----------|---------------------------------------------------------|
| pllClock | PLL clock name (see ccm_analog_pll_clock_t enumeration) |

# 5.5.24 static void CLOCK\_DisableAnalogClock ( CCM\_ANALOG\_Type \* base, clock\_pll\_clke\_t pllClock ) [inline], [static]

### **Parameters**

| base     | CCM_ANALOG base pointer.                                |
|----------|---------------------------------------------------------|
| pllClock | PLL clock name (see ccm_analog_pll_clock_t enumeration) |

# 5.5.25 static void CLOCK\_OverrideAnalogClke ( CCM\_ANALOG\_Type \* base, clock\_pll\_clke\_t ovClock, bool override ) [inline], [static]

# Parameters

45

| base     | CCM_ANALOG base pointer.                                                                                      |
|----------|---------------------------------------------------------------------------------------------------------------|
| ovClock  | PLL clock name (see clock_pll_clke_t enumeration)                                                             |
| override | Override the PLL.  • true: Override the PLL clke, CCM will handle it.  • false: Do not override the PLL clke. |

# 5.5.26 static void CLOCK\_OverridePIIPd ( CCM\_ANALOG\_Type \* base, clock\_pll\_ctrl\_t pdClock, bool override ) [inline], [static]

### Parameters

| base     | CCM_ANALOG base pointer.                                                                                      |
|----------|---------------------------------------------------------------------------------------------------------------|
| pdClock  | PLL clock name (see clock_pll_ctrl_t enumeration)                                                             |
| override | Override the PLL.  • true: Override the PLL clke, CCM will handle it.  • false: Do not override the PLL clke. |

## 5.5.27 void CLOCK InitArmPII ( const ccm\_analog\_frac\_pll\_config\_t \* config\_)

### **Parameters**

| config | Pointer to the configuration structure(see ccm_analog_frac_pll_config_t enumera- |
|--------|----------------------------------------------------------------------------------|
|        | tion).                                                                           |

### Note

This function can't detect whether the Arm PLL has been enabled and used by some IPs.

# $5.5.28 \quad void \ CLOCK\_InitSysPII1 \ ( \ const \ ccm\_analog\_sscg\_pll\_config\_t * \textit{config} \ )$

### **Parameters**

| config | Pointer to the configuration structure(see ccm_analog_sscg_pll_config_t enumera- |
|--------|----------------------------------------------------------------------------------|
|        | tion).                                                                           |

### Note

This function can't detect whether the SYS PLL has been enabled and used by some IPs.

## 5.5.29 void CLOCK InitSysPII2 ( const ccm\_analog\_sscg\_pll\_config\_t \* config )

### **Parameters**

| config | Pointer to the configuration structure(see ccm_analog_sscg_pll_config_t enumera- |
|--------|----------------------------------------------------------------------------------|
|        | tion).                                                                           |

### Note

This function can't detect whether the SYS PLL has been enabled and used by some IPs.

# 5.5.30 void CLOCK\_InitSysPII3 ( const ccm\_analog\_sscg\_pll\_config\_t \* config )

### Parameters

| config | Pointer to the configuration structure(see ccm_analog_sscg_pll_config_t enumera- |
|--------|----------------------------------------------------------------------------------|
|        | tion).                                                                           |

### Note

This function can't detect whether the SYS PLL has been enabled and used by some IPs.

# $5.5.31 \quad void \ CLOCK\_InitDramPII \ ( \ const \ ccm\_analog\_sscg\_pll\_config\_t * \textit{config} \ )$

47

### **Parameters**

| config | Pointer to the configuration structure(see ccm_analog_sscg_pll_config_t enumera- |
|--------|----------------------------------------------------------------------------------|
|        | tion).                                                                           |

### Note

This function can't detect whether the DDR PLL has been enabled and used by some IPs.

## 5.5.32 void CLOCK\_InitAudioPII1 ( const ccm\_analog\_frac\_pll\_config\_t \* config )

### **Parameters**

| config | Pointer to the configuration structure(see ccm_analog_frac_pll_config_t enumera- |
|--------|----------------------------------------------------------------------------------|
|        | tion).                                                                           |

### Note

This function can't detect whether the AUDIO PLL has been enabled and used by some IPs.

# 5.5.33 void CLOCK\_InitAudioPII2 ( const ccm\_analog\_frac\_pll\_config\_t \* config )

### Parameters

| config | Pointer to the configuration structure(see ccm_analog_frac_pll_config_t enumera- |
|--------|----------------------------------------------------------------------------------|
|        | tion).                                                                           |

### Note

This function can't detect whether the AUDIO PLL has been enabled and used by some IPs.

# 5.5.34 void CLOCK\_InitVideoPII1 ( const ccm\_analog\_frac\_pll\_config\_t \* config )

### **Parameters**

| config | Pointer to the configuration structure(see ccm_analog_frac_pll_config_t enumera- |
|--------|----------------------------------------------------------------------------------|
|        | tion).                                                                           |

## 5.5.35 void CLOCK\_InitVideoPII2 ( const ccm\_analog\_sscg\_pll\_config\_t \* config )

### **Parameters**

| config | Pointer to the configuration structure(see ccm_analog_sscg_pll_config_t enumera- |
|--------|----------------------------------------------------------------------------------|
|        | tion).                                                                           |

### Note

This function can't detect whether the VIDEO PLL has been enabled and used by some IPs.

# 5.5.36 void CLOCK\_InitSSCGPII ( CCM\_ANALOG\_Type \* base, const ccm\_analog\_sscg\_pll\_config\_t \* config, clock\_pll\_ctrl\_t type )

### Parameters

| base   | CCM ANALOG base address                                                          |
|--------|----------------------------------------------------------------------------------|
| config | Pointer to the configuration structure(see ccm_analog_sscg_pll_config_t enumera- |
|        | tion).                                                                           |
| type   | sscg pll type                                                                    |

# 5.5.37 uint32\_t CLOCK\_GetSSCGPIIFreq ( CCM\_ANALOG\_Type \* base, clock\_pll\_ctrl\_t type, uint32\_t refClkFreq, bool pll1Bypass )

### **Parameters**

| type       | sscg pll type    |
|------------|------------------|
| pll1Bypass | pll1 bypass flag |

### Returns

Clock frequency

# 5.5.38 void CLOCK\_InitFracPII ( CCM\_ANALOG\_Type \* base, const ccm\_analog\_frac\_pll\_config\_t \* config, clock\_pll\_ctrl\_t type )

### **Parameters**

| base   | CCM ANALOG base address.                                                              |
|--------|---------------------------------------------------------------------------------------|
| config | Pointer to the configuration structure(see ccm_analog_frac_pll_config_t enumeration). |
| type   | fractional pll type.                                                                  |

# 5.5.39 uint32 t CLOCK GetFracPllFreq ( CCM ANALOG Type \* base, clock\_pll\_ctrl\_t type, uint32\_t refClkFreq )

### Parameters

| base       | CCM_ANALOG base pointer.      |
|------------|-------------------------------|
| type       | fractional pll type.          |
| fractional | pll reference clock frequency |

### Returns

Clock frequency

# 5.5.40 uint32\_t CLOCK\_GetPIIFreq ( clock\_pll\_ctrl\_t pll )

MCUXpresso SDK API Reference Manual

**Parameters** 

type fractional pll type.

Returns

Clock frequency

# 5.5.41 uint32\_t CLOCK\_GetPIIRefClkFreq ( clock\_pll\_ctrl\_t ctrl )

**Parameters** 

type | fractional pll type.

Returns

Clock frequency

# 5.5.42 uint32\_t CLOCK\_GetFreq ( clock\_name\_t clockName )

This function checks the current clock configurations and then calculates the clock frequency for a specific clock name defined in clock\_name\_t.

Parameters

clockName | Clock names defined in clock\_name\_t

Returns

Clock frequency value in hertz

# 5.5.43 uint32\_t CLOCK\_GetCoreM4Freq ( void )

Returns

Clock frequency; If the clock is invalid, returns 0.

## 5.5.44 uint32\_t CLOCK\_GetAxiFreq ( void )

Returns

Clock frequency; If the clock is invalid, returns 0.

# 5.5.45 uint32\_t CLOCK\_GetAhbFreq ( void )

Returns

Clock frequency; If the clock is invalid, returns 0.

# **Chapter 6**

# **ECSPI: Serial Peripheral Interface Driver**

#### **Overview** 6.1

## **Modules**

- ECSPI DriverECSPI FreeRTOS Driver

### **ECSPI Driver**

### 6.2 ECSPI Driver

### 6.2.1 Overview

ECSPI driver includes functional APIs and transactional APIs.

Functional APIs are feature/property target low level APIs. Functional APIs can be used for ECSPI initialization/configuration/operation for optimization/customization purpose. Using the functional API requires the knowledge of the SPI peripheral and how to organize functional APIs to meet the application requirements. All functional API use the peripheral base address as the first parameter. ECSPI functional operation groups provide the functional API set.

Transactional APIs are transaction target high level APIs. Transactional APIs can be used to enable the peripheral and in the application if the code size and performance of transactional APIs satisfy the requirements. If the code size and performance are a critical requirement, see the transactional API implementation and write a custom code. All transactional APIs use the spi\_handle\_t as the first parameter. Initialize the handle by calling the SPI\_MasterTransferCreateHandle() or SPI\_SlaveTransferCreateHandle() API.

Transactional APIs support asynchronous transfer. This means that the functions SPI\_MasterTransferNon-Blocking() and SPI\_SlaveTransferNonBlocking() set up the interrupt for data transfer. When the transfer completes, the upper layer is notified through a callback function with the kStatus\_SPI\_Idle status.

## 6.2.2 Typical use case

### 6.2.2.1 SPI master transfer using polling method

Refer to the driver examples codes located at <SDK\_ROOT>/boards/<BOARD>/driver\_examples/ecspi

### 6.2.2.2 SPI master transfer using an interrupt method

Refer to the driver examples codes located at <SDK\_ROOT>/boards/<BOARD>/driver\_examples/ecspi

### **Data Structures**

- struct ecspi\_channel\_config\_t
  - ECSPI user channel configure structure. More...
- struct ecspi\_master\_config\_t
  - ECSPI master configure structure. More...
- struct ecspi\_slave\_config\_t
  - ECSPI slave configure structure. More...
- struct ecspi\_transfer\_t
  - ECSPI transfer structure. More...
- struct ecspi master handle t

ECSPI master handle structure. More...

# **Macros**

• #define ECSPI\_DUMMYDATA (0xFFFFFFFU)

ECSPI dummy transfer data, the data is sent while txBuff is NULL.

# **Typedefs**

- typedef ecspi\_master\_handle\_t ecspi\_slave\_handle\_t Slave handle is the same with master handle.
- typedef void(\* ecspi\_master\_callback\_t )(ECSPI\_Type \*base, ecspi\_master\_handle\_t \*handle, status\_t status, void \*userData)

ECSPI master callback for finished transmit.

• typedef void(\* ecspi\_slave\_callback\_t)(ECSPI\_Type \*base, ecspi\_slave\_handle\_t \*handle, status\_t status, void \*userData)

ECSPI slave callback for finished transmit.

# **Enumerations**

```
enum _ecspi_status {
 kStatus_ECSPI_Busy = MAKE_STATUS(kStatusGroup_ECSPI, 0),
 kStatus ECSPI Idle = MAKE STATUS(kStatusGroup ECSPI, 1),
 kStatus_ECSPI_Error = MAKE_STATUS(kStatusGroup_ECSPI, 2),
 kStatus ECSPI HardwareOverFlow = MAKE STATUS(kStatusGroup ECSPI, 3) }
    Return status for the ECSPI driver.
enum ecspi_clock_polarity_t {
 kECSPI PolarityActiveHigh = 0x0U,
 kECSPI_PolarityActiveLow }
    ECSPI clock polarity configuration.
enum ecspi_clock_phase_t {
 kECSPI ClockPhaseFirstEdge,
 kECSPI ClockPhaseSecondEdge }
    ECSPI clock phase configuration.
enum _ecspi_interrupt_enable {
 kECSPI_TxfifoEmptyInterruptEnable = ECSPI_INTREG_TEEN_MASK,
 kECSPI_TxFifoDataRequstInterruptEnable = ECSPI_INTREG_TDREN_MASK,
 kECSPI TxFifoFullInterruptEnable = ECSPI INTREG TFEN MASK,
 kECSPI_RxFifoReadyInterruptEnable = ECSPI_INTREG_RREN_MASK,
 kECSPI RxFifoDataRegustInterruptEnable = ECSPI INTREG RDREN MASK,
 kECSPI RxFifoFullInterruptEnable = ECSPI INTREG RFEN MASK,
 kECSPI_RxFifoOverFlowInterruptEnable = ECSPI_INTREG_ROEN_MASK,
 kECSPI_TransferCompleteInterruptEnable = ECSPI_INTREG_TCEN_MASK,
 kECSPI AllInterruptEnable }
    ECSPI interrupt sources.
enum _ecspi_flags {
```

MCUXpresso SDK API Reference Manual

```
kECSPI TxfifoEmptyFlag = ECSPI STATREG TE MASK,
 kECSPI_TxFifoDataRequstFlag = ECSPI_STATREG_TDR_MASK,
 kECSPI_TxFifoFullFlag = ECSPI_STATREG_TF_MASK,
 kECSPI_RxFifoReadyFlag = ECSPI_STATREG_RR_MASK,
 kECSPI_RxFifoDataRequstFlag = ECSPI_STATREG_RDR_MASK,
 kECSPI_RxFifoFullFlag = ECSPI_STATREG_RF_MASK,
 kECSPI_RxFifoOverFlowFlag = ECSPI_STATREG_RO_MASK,
 kECSPI_TransferCompleteFlag = ECSPI_STATREG_TC_MASK }
    ECSPI status flags.

 enum ecspi dma enable t {

 kECSPI_TxDmaEnable = ECSPI_DMAREG_TEDEN_MASK,
 kECSPI_RxDmaEnable = ECSPI_DMAREG_RXDEN_MASK,
 kECSPI_DmaAllEnable = (ECSPI_DMAREG_TEDEN_MASK | ECSPI_DMAREG_RXDEN_M-
  ASK) }
    ECSPI DMA enable.
enum ecspi_Data_ready_t {
 kECSPI_DataReadyIgnore = 0x0U,
 kECSPI DataReadyFallingEdge,
 kECSPI_DataReadyLowLevel }
    ECSPI SPI_RDY signal configuration.
enum ecspi_channel_source_t {
 kECSPI Channel = 0x0U,
 kECSPI Channel1,
 kECSPI_Channel2,
 kECSPI_Channel3 }
    ECSPI channel select source.
enum ecspi_master_slave_mode_t {
 kECSPI Slave = 0U,
 kECSPI_Master }
    ECSPI master or slave mode configuration.
• enum ecspi data line inactive state t {
 kECSPI DataLineInactiveStateHigh = 0x0U,
 kECSPI_DataLineInactiveStateLow }
    ECSPI data line inactive state configuration.
enum ecspi_clock_inactive_state_t {
 kECSPI_ClockInactiveStateLow = 0x0U,
 kECSPI ClockInactiveStateHigh }
    ECSPI clock inactive state configuration.
• enum ecspi_chip_select_active_state_t {
  kECSPI_ChipSelectActiveStateLow = 0x0U,
 kECSPI ChipSelectActiveStateHigh }
    ECSPI active state configuration.
enum ecspi_wave_form_t {
 kECSPI_WaveFormSingle = 0x0U,
 kECSPI WaveFormMultiple }
    ECSPI wave form configuration.
enum ecspi_sample_period_clock_source_t {
```

```
kECSPI_spiClock = 0x0U,
kECSPI_lowFreqClock }
    ECSPI sample period clock configuration.
```

# **Functions**

• uint32\_t ECSPI\_GetInstance (ECSPI\_Type \*base) Get the instance for ECSPI module.

# **Driver version**

• #define FSL\_ECSPI\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 0)) ECSPI driver version 2.0.0.

# Initialization and deinitialization

- void ECSPI\_MasterGetDefaultConfig (ecspi\_master\_config\_t \*config)
  - Sets the ECSPI configuration structure to default values.
- void ECSPI\_MasterInit (ECSPI\_Type \*base, const ecspi\_master\_config\_t \*config, uint32\_t src-Clock\_Hz)

*Initializes the ECSPI with configuration.* 

- void ECSPI\_SlaveGetDefaultConfig (ecspi\_slave\_config\_t \*config)
  - Sets the ECSPI configuration structure to default values.
- void ECSPI\_SlaveInit (ECSPI\_Type \*base, const ecspi\_slave\_config\_t \*config)

Initializes the ECSPI with configuration.

• void ECSPI\_Deinit (ECSPI\_Type \*base)

De-initializes the ECSPI.

• static void ECSPI\_Enable (ECSPI\_Type \*base, bool enable)

Enables or disables the ECSPL

### Status

- static uint32\_t ECSPI\_GetStatusFlags (ECSPI\_Type \*base)
  - Gets the status flag.
- static void ECSPI\_ClearStatusFlags (ECSPI\_Type \*base, uint32\_t mask) Clear the status flag.

# Interrupts

- static void ECSPI\_EnableInterrupts (ECSPI\_Type \*base, uint32\_t mask) Enables the interrupt for the ECSPI.
- static void ECSPI\_DisableInterrupts (ECSPI\_Type \*base, uint32\_t mask)

  Disables the interrupt for the ECSPI.

MCUXpresso SDK API Reference Manual

# **Software Reset**

• static void ECSPI\_SoftwareReset (ECSPI\_Type \*base) Software reset.

### Channel mode check

• static bool ECSPI\_IsMaster (ECSPI\_Type \*base, ecspi\_channel\_source\_t channel)

\*Mode check.

# **DMA Control**

• static void ECSPI\_EnableDMA (ECSPI\_Type \*base, uint32\_t mask, bool enable) Enables the DMA source for ECSPI.

# **FIFO Operation**

- static uint8\_t ECSPI\_GetTxFifoCount (ECSPI\_Type \*base)
  - Get the Tx FIFO data count.
- static uint8\_t ECSPI\_GetRxFifoCount (ECSPI\_Type \*base)

  Get the Rx FIFO data count.

# **Bus Operations**

- static void ECSPI\_SetChannelSelect (ECSPI\_Type \*base, ecspi\_channel\_source\_t channel) Set channel select for transfer.
- void ECSPI\_SetChannelConfig (ECSPI\_Type \*base, ecspi\_channel\_source\_t channel, const ecspi\_channel\_config\_t \*config)

Set channel select configuration for transfer.

- void ECSPI\_SetBaudRate (ECSPI\_Type \*base, uint32\_t baudRate\_Bps, uint32\_t srcClock\_Hz) Sets the baud rate for ECSPI transfer.
- void ECSPI\_WriteBlocking (ECSPI\_Type \*base, uint32\_t \*buffer, size\_t size)

Sends a buffer of data bytes using a blocking method.

• static void ECSPI\_WriteData (ECSPI\_Type \*base, uint32\_t data)

Writes a data into the ECSPI data register.

• static uint32 t ECSPI ReadData (ECSPI Type \*base)

Gets a data from the ECSPI data register.

Initializes the ECSPI master handle.

# **Transactional**

• void ECSPI\_MasterTransferCreateHandle (ECSPI\_Type \*base, ecspi\_master\_handle\_t \*handle, ecspi\_master\_callback\_t callback, void \*userData)

• status\_t ECSPI\_MasterTransferBlocking (ECSPI\_Type \*base, ecspi\_transfer\_t \*xfer)

MCUXpresso SDK API Reference Manual

Transfers a block of data using a polling method.

• status\_t ECSPI\_MasterTransferNonBlocking (ECSPI\_Type \*base, ecspi\_master\_handle\_t \*handle, ecspi\_transfer\_t \*xfer)

Performs a non-blocking ECSPI interrupt transfer.

• status\_t ECSPI\_MasterTransferGetCount (ECSPI\_Type \*base, ecspi\_master\_handle\_t \*handle, size t \*count)

Gets the bytes of the ECSPI interrupt transferred.

- void ECSPI\_MasterTransferAbort (ECSPI\_Type \*base, ecspi\_master\_handle\_t \*handle)

  Aborts an ECSPI transfer using interrupt.
- void ECSPI\_MasterTransferHandleIRQ (ECSPI\_Type \*base, ecspi\_master\_handle\_t \*handle)

  Interrupts the handler for the ECSPI.
- void ECSPI\_SlaveTransferCreateHandle (ECSPI\_Type \*base, ecspi\_slave\_handle\_t \*handle, ecspi\_slave\_callback\_t callback, void \*userData)

Initializes the ECSPI slave handle.

• static status\_t ECSPI\_SlaveTransferNonBlocking (ECSPI\_Type \*base, ecspi\_slave\_handle\_t \*handle, ecspi\_transfer\_t \*xfer)

Performs a non-blocking ECSPI slave interrupt transfer.

static status\_t ECSPI\_SlaveTransferGetCount (ECSPI\_Type \*base, ecspi\_slave\_handle\_t \*handle, size\_t \*count)

Gets the bytes of the ECSPI interrupt transferred.

- static void ECSPI\_SlaveTransferAbort (ECSPI\_Type \*base, ecspi\_slave\_handle\_t \*handle)

  Aborts an ECSPI slave transfer using interrupt.
- void ECSPI\_SlaveTransferHandleIRQ (ECSPI\_Type \*base, ecspi\_slave\_handle\_t \*handle)

  Interrupts a handler for the ECSPI slave.

# 6.2.3 Data Structure Documentation

# 6.2.3.1 struct ecspi channel config t

# **Data Fields**

• ecspi\_master\_slave\_mode\_t channelMode

Channel mode.

• ecspi clock inactive state t clockInactiveState

Clock line (SCLK) inactive state.

• ecspi\_data\_line\_inactive\_state\_t dataLineInactiveState

Data line (MOSI&MISO) inactive state.

• ecspi\_chip\_select\_active\_state\_t chipSlectActiveState

*Chip select(SS) line active state.* 

• ecspi\_wave\_form\_t waveForm

Wave form.

ecspi\_clock\_polarity\_t polarity

Clock polarity.

ecspi\_clock\_phase\_t phase

Clock phase.

# 6.2.3.2 struct ecspi\_master\_config\_t

# **Data Fields**

ecspi\_channel\_source\_t channel

Channel number.

• ecspi\_channel\_config\_t channelConfig

Channel configuration.

ecspi\_sample\_period\_clock\_source\_t samplePeriodClock

Sample period clock source.

• uint8 t burstLength

Burst length.

• uint8\_t chipSelectDelay

SS delay time.

• uint16 t samplePeriod

Sample period.

• uint8\_t txFifoThreshold

TX Threshold.

• uint8\_t rxFifoThreshold

RX Threshold.

uint32\_t baudRate\_Bps

ECSPI baud rate for master mode.

bool enableLoopback

Enable the ECSPI loopback test.

#### 6.2.3.2.0.1 Field Documentation

# 6.2.3.2.0.1.1 bool ecspi\_master\_config\_t::enableLoopback

# 6.2.3.3 struct ecspi\_slave\_config\_t

#### **Data Fields**

uint8\_t burstLength

Burst length.

uint8\_t txFifoThreshold

TX Threshold.

uint8\_t rxFifoThreshold

RX Threshold.

ecspi\_channel\_config\_t channelConfig

Channel configuration.

# 6.2.3.4 struct ecspi\_transfer\_t

# **Data Fields**

• uint32 t \* txData

Send buffer.

• uint32\_t \* rxData

Receive buffer.

61

• size\_t dataSize

Transfer bytes.

ecspi\_channel\_source\_t channel

ECSPI channel select.

# 6.2.3.5 struct ecspi master handle

# **Data Fields**

• ecspi\_channel\_source\_t channel

Channel number.

• uint32\_t \*volatile txData

Transfer buffer.

• uint32\_t \*volatile rxData

Receive buffer.

• volatile size\_t txRemainingBytes

Send data remaining in bytes.

• volatile size\_t rxRemainingBytes

Receive data remaining in bytes.

• volatile uint32\_t state

ECSPI internal state.

• size t transferSize

Bytes to be transferred.

• ecspi master callback t callback

ECSPI callback.

void \* userData

Callback parameter.

# 6.2.4 Macro Definition Documentation

# 6.2.4.1 #define FSL\_ECSPI\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 0))

# 6.2.4.2 #define ECSPI DUMMYDATA (0xFFFFFFFU)

# 6.2.5 Enumeration Type Documentation

# 6.2.5.1 enum \_ecspi\_status

# Enumerator

kStatus\_ECSPI\_Busy ECSPI bus is busy.

kStatus ECSPI Idle ECSPI is idle.

kStatus\_ECSPI\_Error ECSPI error.

kStatus\_ECSPI\_HardwareOverFlow ECSPI hardware overflow.

MCUXpresso SDK API Reference Manual

# 6.2.5.2 enum ecspi\_clock\_polarity\_t

#### Enumerator

**kECSPI\_PolarityActiveHigh** Active-high ECSPI polarity high (idles low). **kECSPI\_PolarityActiveLow** Active-low ECSPI polarity low (idles high).

# 6.2.5.3 enum ecspi\_clock\_phase\_t

### Enumerator

**kECSPI\_ClockPhaseFirstEdge** First edge on SPSCK occurs at the middle of the first cycle of a data transfer.

**kECSPI\_ClockPhaseSecondEdge** First edge on SPSCK occurs at the start of the first cycle of a data transfer.

# 6.2.5.4 enum \_ecspi\_interrupt\_enable

### Enumerator

kECSPI\_TxfifoEmptyInterruptEnable Transmit FIFO buffer empty interrupt.

kECSPI\_TxFifoDataRequstInterruptEnable Transmit FIFO data requst interrupt.

kECSPI TxFifoFullInterruptEnable Transmit FIFO full interrupt.

kECSPI\_RxFifoReadyInterruptEnable Receiver FIFO ready interrupt.

kECSPI\_RxFifoDataRegustInterruptEnable Receiver FIFO data requst interrupt.

kECSPI\_RxFifoFullInterruptEnable Receiver FIFO full interrupt.

**kECSPI\_RxFifoOverFlowInterruptEnable** Receiver FIFO buffer overflow interrupt.

kECSPI\_TransferCompleteInterruptEnable Transfer complete interrupt.

*kECSPI\_AllInterruptEnable* All interrupt.

# 6.2.5.5 enum \_ecspi\_flags

#### Enumerator

**kECSPI\_TxfifoEmptyFlag** Transmit FIFO buffer empty flag.

kECSPI\_TxFifoDataRegustFlag Transmit FIFO data requst flag.

kECSPI\_TxFifoFullFlag Transmit FIFO full flag.

**kECSPI\_RxFifoReadyFlag** Receiver FIFO ready flag.

kECSPI\_RxFifoDataRegustFlag Receiver FIFO data requst flag.

kECSPI\_RxFifoFullFlag Receiver FIFO full flag.

kECSPI RxFifoOverFlowFlag Receiver FIFO buffer overflow flag.

kECSPI\_TransferCompleteFlag Transfer complete flag.

# **MCUXpresso SDK API Reference Manual**

63

# 6.2.5.6 enum \_ecspi\_dma\_enable\_t

#### Enumerator

```
kECSPI_TxDmaEnablekECSPI_RxDmaEnablekECSPI_DmaAllEnableAll DMA request source.
```

# 6.2.5.7 enum ecspi Data ready t

#### Enumerator

```
kECSPI_DataReadyIgnore SPI_RDY signal is ignored.kECSPI_DataReadyFallingEdge SPI_RDY signal will be triggerd by the falling edge.kECSPI_DataReadyLowLevel SPI_RDY signal will be triggerd by a low level.
```

# **6.2.5.8 enum ecspi\_channel\_source\_t**

#### Enumerator

```
kECSPI_Channel0 Channel 0 is selectd.
kECSPI_Channel1 Channel 1 is selectd.
kECSPI_Channel2 Channel 2 is selectd.
kECSPI_Channel3 Channel 3 is selectd.
```

# 6.2.5.9 enum ecspi\_master\_slave\_mode\_t

### Enumerator

```
kECSPI_Master ECSPI peripheral operates in slave mode. kECSPI_Master ECSPI peripheral operates in master mode.
```

# 6.2.5.10 enum ecspi\_data\_line\_inactive\_state\_t

### Enumerator

```
kECSPI_DataLineInactiveStateHigh The data line inactive state stays high. kECSPI_DataLineInactiveStateLow The data line inactive state stays low.
```

NXP Semiconductors

# **MCUXpresso SDK API Reference Manual**

# 6.2.5.11 enum ecspi\_clock\_inactive\_state\_t

### Enumerator

**kECSPI\_ClockInactiveStateLow** The SCLK inactive state stays low. **kECSPI\_ClockInactiveStateHigh** The SCLK inactive state stays high.

# 6.2.5.12 enum ecspi\_chip\_select\_active\_state\_t

#### Enumerator

**kECSPI\_ChipSelectActiveStateLow** The SS signal line active stays low. **kECSPI\_ChipSelectActiveStateHigh** The SS signal line active stays high.

# 6.2.5.13 enum ecspi\_wave\_form\_t

### Enumerator

**kECSPI\_WaveFormSingle** The wave form for signal burst. **kECSPI\_WaveFormMultiple** The wave form for multiple burst.

# 6.2.5.14 enum ecspi\_sample\_period\_clock\_source\_t

# Enumerator

kECSPI\_spiClock The sample period clock source is SCLK.kECSPI\_lowFreqClock The sample seriod clock source is low\_frequency reference clock(32.768 kHz).

# 6.2.6 Function Documentation

# 6.2.6.1 uint32 t ECSPI GetInstance ( ECSPI Type \* base )

# **Parameters**

| base | ECSPI base address |
|------|--------------------|

# 6.2.6.2 void ECSPI\_MasterGetDefaultConfig ( ecspi\_master\_config\_t \* config )

The purpose of this API is to get the configuration structure initialized for use in ECSPI\_MasterInit(). User may use the initialized structure unchanged in ECSPI\_MasterInit, or modify some fields of the structure before calling ECSPI\_MasterInit. After calling this API, the master is ready to transfer. Example:

### MCUXpresso SDK API Reference Manual

```
ecspi_master_config_t config;
ECSPI_MasterGetDefaultConfig(&config);
```

#### **Parameters**

| config | pointer to config structure |
|--------|-----------------------------|
|--------|-----------------------------|

# 6.2.6.3 void ECSPI\_MasterInit ( ECSPI\_Type \* base, const ecspi\_master\_config\_t \* config, uint32\_t srcClock\_Hz )

The configuration structure can be filled by user from scratch, or be set with default values by ECSPI\_MasterGetDefaultConfig(). After calling this API, the slave is ready to transfer. Example

```
ecspi_master_config_t config = {
.baudRate_Bps = 400000,
...
};
ECSPI_MasterInit(ECSPI0, &config);
```

#### **Parameters**

| base        | ECSPI base pointer                        |
|-------------|-------------------------------------------|
| config      | pointer to master configuration structure |
| srcClock_Hz | Source clock frequency.                   |

# 6.2.6.4 void ECSPI\_SlaveGetDefaultConfig ( ecspi\_slave\_config\_t \* config )

The purpose of this API is to get the configuration structure initialized for use in ECSPI\_SlaveInit(). User may use the initialized structure unchanged in ECSPI\_SlaveInit(), or modify some fields of the structure before calling ECSPI\_SlaveInit(). After calling this API, the master is ready to transfer. Example:

```
ecspi_Slaveconfig_t config;
ECSPI_SlaveGetDefaultConfig(&config);
```

#### **Parameters**

| config | pointer to config structure |
|--------|-----------------------------|
|--------|-----------------------------|

# 6.2.6.5 void ECSPI\_SlaveInit ( ECSPI\_Type \* base, const ecspi\_slave\_config\_t \* config )

The configuration structure can be filled by user from scratch, or be set with default values by ECSPI\_-SlaveGetDefaultConfig(). After calling this API, the slave is ready to transfer. Example

### MCUXpresso SDK API Reference Manual

```
ecspi_Salveconfig_t config = {
   .baudRate_Bps = 400000,
   ...
};
ECSPI_SlaveInit(ECSPI1, &config);
```

#### **Parameters**

| base   | ECSPI base pointer                        |
|--------|-------------------------------------------|
| config | pointer to master configuration structure |

# 6.2.6.6 void ECSPI\_Deinit ( ECSPI\_Type \* base )

Calling this API resets the ECSPI module, gates the ECSPI clock. The ECSPI module can't work unless calling the ECSPI\_MasterInit/ECSPI\_SlaveInit to initialize module.

### **Parameters**

| base | ECSPI base pointer |
|------|--------------------|
|------|--------------------|

# 

### Parameters

| base   | ECSPI base pointer                                  |
|--------|-----------------------------------------------------|
| enable | pass true to enable module, false to disable module |

# 

### **Parameters**

# Returns

ECSPI Status, use status flag to AND <u>ecspi\_flags</u> could get the related status.

# 6.2.6.9 static void ECSPI\_ClearStatusFlags ( ECSPI\_Type \* base, uint32\_t mask ) [inline], [static]

# **MCUXpresso SDK API Reference Manual**

67

# Parameters

| base | ECSPI base pointer                                                              |
|------|---------------------------------------------------------------------------------|
| mask | ECSPI Status, use status flag to AND _ecspi_flags could get the related status. |

# 6.2.6.10 static void ECSPI\_EnableInterrupts ( ECSPI\_Type \* base, uint32\_t mask ) [inline], [static]

# Parameters

| base | ECSPI base pointer                                                            |
|------|-------------------------------------------------------------------------------|
| mask | ECSPI interrupt source. The parameter can be any combination of the following |
|      | values:                                                                       |
|      | <ul> <li>kECSPI_TxfifoEmptyInterruptEnable</li> </ul>                         |
|      | <ul> <li>kECSPI_TxFifoDataRequstInterruptEnable</li> </ul>                    |
|      | kECSPI_TxFifoFullInterruptEnable                                              |
|      | kECSPI_RxFifoReadyInterruptEnable                                             |
|      | kECSPI_RxFifoDataRequstInterruptEnable                                        |
|      | kECSPI_RxFifoFullInterruptEnable                                              |
|      | • kECSPI_RxFifoOverFlowInterruptEnable                                        |
|      | kECSPI_TransferCompleteInterruptEnable                                        |
|      | kECSPI_AllInterruptEnable                                                     |
|      | •                                                                             |

# 6.2.6.11 static void ECSPI\_DisableInterrupts ( ECSPI\_Type \* base, uint32\_t mask ) [inline], [static]

# **Parameters**

| base | ECSPI base pointer                                                            |
|------|-------------------------------------------------------------------------------|
| mask | ECSPI interrupt source. The parameter can be any combination of the following |
|      | values:                                                                       |
|      | kECSPI_TxfifoEmptyInterruptEnable                                             |
|      | kECSPI_TxFifoDataRequstInterruptEnable                                        |
|      | kECSPI_TxFifoFullInterruptEnable                                              |
|      | kECSPI_RxFifoReadyInterruptEnable                                             |
|      | kECSPI_RxFifoDataRequstInterruptEnable                                        |
|      | kECSPI_RxFifoFullInterruptEnable                                              |
|      | <ul> <li>kECSPI_RxFifoOverFlowInterruptEnable</li> </ul>                      |
|      | kECSPI_TransferCompleteInterruptEnable                                        |
|      | kECSPI_AllInterruptEnable                                                     |
|      |                                                                               |

# 

# **Parameters**

| base | ECSPI base pointer |
|------|--------------------|

# 6.2.6.13 static bool ECSPI\_IsMaster ( ECSPI\_Type \* base, ecspi\_channel\_source\_t channel ) [inline], [static]

### **Parameters**

| base    | ECSPI base pointer   |
|---------|----------------------|
| channel | ECSPI channel source |

### Returns

mode of channel

# 6.2.6.14 static void ECSPI\_EnableDMA ( ECSPI\_Type \* base, uint32\_t mask, bool enable ) [inline], [static]

# **MCUXpresso SDK API Reference Manual**

### **Parameters**

| base   | ECSPI base pointer                             |
|--------|------------------------------------------------|
| source | ECSPI DMA source.                              |
| enable | True means enable DMA, false means disable DMA |

# 

### Parameters

| base | ECSPI base pointer. |
|------|---------------------|

# Returns

the number of words in Tx FIFO buffer.

# 

# **Parameters**

| base | ECSPI base pointer. |
|------|---------------------|

# Returns

the number of words in Rx FIFO buffer.

# 6.2.6.17 static void ECSPI\_SetChannelSelect ( ECSPI\_Type \* base, ecspi\_channel\_source\_t channel ) [inline], [static]

### **Parameters**

| base | ECSPI base pointer |
|------|--------------------|

| channel | Channel source. |
|---------|-----------------|
|---------|-----------------|

# 6.2.6.18 void ECSPI\_SetChannelConfig ( ECSPI\_Type \* base, ecspi\_channel\_source\_t channel, const ecspi\_channel\_config\_t \* config\_)

The purpose of this API is to set the channel will be use to transfer. User may use this API after instance has been initialized or before transfer start. The configuration structure #\_ecspi\_channel\_config\_ can be filled by user from scratch. After calling this API, user can select this channel as transfer channel.

# Parameters

| base    | ECSPI base pointer              |
|---------|---------------------------------|
| channel | Channel source.                 |
| config  | Configuration struct of channel |

# 6.2.6.19 void ECSPI\_SetBaudRate ( ECSPI\_Type \* base, uint32\_t baudRate\_Bps, uint32\_t srcClock\_Hz )

This is only used in master.

# **Parameters**

| base         | ECSPI base pointer                  |
|--------------|-------------------------------------|
| baudRate_Bps | baud rate needed in Hz.             |
| srcClock_Hz  | ECSPI source clock frequency in Hz. |

# 6.2.6.20 void ECSPI\_WriteBlocking ( ECSPI\_Type \* base, uint32\_t \* buffer, size\_t size )

Note

This function blocks via polling until all bytes have been sent.

### **Parameters**

| base | ECSPI base pointer |
|------|--------------------|
|------|--------------------|

| buffer | The data bytes to send           |
|--------|----------------------------------|
| size   | The number of data bytes to send |

# 

### Parameters

| base | ECSPI base pointer      |
|------|-------------------------|
| data | Data needs to be write. |

# 6.2.6.22 static uint32\_t ECSPI\_ReadData ( ECSPI\_Type \* base ) [inline], [static]

# **Parameters**

| base | ECSPI base pointer |
|------|--------------------|
|------|--------------------|

# Returns

Data in the register.

# 6.2.6.23 void ECSPI\_MasterTransferCreateHandle ( ECSPI\_Type \* base, ecspi\_master\_handle\_t \* handle, ecspi\_master\_callback\_t callback, void \* userData )

This function initializes the ECSPI master handle which can be used for other ECSPI master transactional APIs. Usually, for a specified ECSPI instance, call this API once to get the initialized handle.

# Parameters

| base     | ECSPI peripheral base address. |
|----------|--------------------------------|
| handle   | ECSPI handle pointer.          |
| callback | Callback function.             |

| userData | User data. |
|----------|------------|
|----------|------------|

# 6.2.6.24 status\_t ECSPI\_MasterTransferBlocking ( ECSPI\_Type \* base, ecspi\_transfer\_t \* xfer )

# **Parameters**

| base | SPI base pointer                       |
|------|----------------------------------------|
| xfer | pointer to spi_xfer_config_t structure |

# Return values

| kStatus_Success         | Successfully start a transfer. |
|-------------------------|--------------------------------|
| kStatus_InvalidArgument | Input argument is invalid.     |

# 6.2.6.25 status\_t ECSPI\_MasterTransferNonBlocking ( ECSPI\_Type \* base, ecspi\_master\_handle\_t \* handle, ecspi\_transfer\_t \* xfer )

Note

The API immediately returns after transfer initialization is finished. If ECSPI transfer data frame size is 16 bits, the transfer size cannot be an odd number.

# **Parameters**

| base   | ECSPI peripheral base address.                                             |
|--------|----------------------------------------------------------------------------|
| handle | pointer to ecspi_master_handle_t structure which stores the transfer state |
| xfer   | pointer to ecspi_transfer_t structure                                      |

# Return values

| kStatus_Success         | Successfully start a transfer.                  |
|-------------------------|-------------------------------------------------|
| kStatus_InvalidArgument | Input argument is invalid.                      |
| kStatus_ECSPI_Busy      | ECSPI is not idle, is running another transfer. |

# 6.2.6.26 status\_t ECSPI\_MasterTransferGetCount ( ECSPI\_Type \* base, ecspi\_master\_handle\_t \* handle, size\_t \* count )

# MCUXpresso SDK API Reference Manual

73

### **Parameters**

| base   | ECSPI peripheral base address.                                      |
|--------|---------------------------------------------------------------------|
| handle | Pointer to ECSPI transfer handle, this should be a static variable. |
| count  | Transferred bytes of ECSPI master.                                  |

### Return values

| kStatus_ECSPI_Success | Succeed get the transfer count.                                |
|-----------------------|----------------------------------------------------------------|
| kStatus_NoTransferIn- | There is not a non-blocking transaction currently in progress. |
| Progress              |                                                                |

# 6.2.6.27 void ECSPI\_MasterTransferAbort ( ECSPI\_Type \* base, ecspi\_master\_handle\_t \* handle )

### **Parameters**

| base   | ECSPI peripheral base address.                                      |
|--------|---------------------------------------------------------------------|
| handle | Pointer to ECSPI transfer handle, this should be a static variable. |

# 6.2.6.28 void ECSPI\_MasterTransferHandleIRQ ( ECSPI\_Type \* base, ecspi\_master\_handle\_t \* handle )

### Parameters

| base   | ECSPI peripheral base address.                                              |
|--------|-----------------------------------------------------------------------------|
| handle | pointer to ecspi_master_handle_t structure which stores the transfer state. |

# 6.2.6.29 void ECSPI\_SlaveTransferCreateHandle ( ECSPI\_Type \* base, ecspi\_slave\_handle\_t \* handle, ecspi\_slave\_callback\_t callback, void \* userData )

This function initializes the ECSPI slave handle which can be used for other ECSPI slave transactional APIs. Usually, for a specified ECSPI instance, call this API once to get the initialized handle.

### **Parameters**

| base     | ECSPI peripheral base address. |
|----------|--------------------------------|
| handle   | ECSPI handle pointer.          |
| callback | Callback function.             |
| userData | User data.                     |

# 6.2.6.30 static status\_t ECSPI\_SlaveTransferNonBlocking ( ECSPI\_Type \* base, ecspi\_slave\_handle\_t \* handle, ecspi\_transfer\_t \* xfer ) [inline], [static]

Note

The API returns immediately after the transfer initialization is finished.

# Parameters

| base   | ECSPI peripheral base address.                                             |
|--------|----------------------------------------------------------------------------|
| handle | pointer to ecspi_master_handle_t structure which stores the transfer state |
| xfer   | pointer to ecspi_transfer_t structure                                      |

# Return values

| kStatus_Success Successfully start a transfer. |                                                 |
|------------------------------------------------|-------------------------------------------------|
| kStatus_InvalidArgument                        | Input argument is invalid.                      |
| kStatus_ECSPI_Busy                             | ECSPI is not idle, is running another transfer. |

# 6.2.6.31 static status\_t ECSPI\_SlaveTransferGetCount ( ECSPI\_Type \* base, ecspi\_slave\_handle\_t \* handle, size\_t \* count ) [inline], [static]

# **Parameters**

| base   | ECSPI peripheral base address.                                      |
|--------|---------------------------------------------------------------------|
| handle | Pointer to ECSPI transfer handle, this should be a static variable. |
| count  | Transferred bytes of ECSPI slave.                                   |

MCUXpresso SDK API Reference Manual

# Return values

| kStatus_ECSPI_Success             | Succeed get the transfer count.                                |
|-----------------------------------|----------------------------------------------------------------|
| kStatus_NoTransferIn-<br>Progress | There is not a non-blocking transaction currently in progress. |

# 6.2.6.32 static void ECSPI\_SlaveTransferAbort ( ECSPI\_Type \* base, ecspi\_slave\_handle\_t \* handle ) [inline], [static]

# **Parameters**

| base   | ECSPI peripheral base address.                                      |
|--------|---------------------------------------------------------------------|
| handle | Pointer to ECSPI transfer handle, this should be a static variable. |

# 6.2.6.33 void ECSPI\_SlaveTransferHandleIRQ ( ECSPI\_Type \* base, ecspi\_slave\_handle\_t \* handle )

# Parameters

| base   | ECSPI peripheral base address.                                            |
|--------|---------------------------------------------------------------------------|
| handle | pointer to ecspi_slave_handle_t structure which stores the transfer state |

# **ECSPI FreeRTOS Driver**

# 6.3 ECSPI FreeRTOS Driver

# 6.3.1 Overview

# **Driver version**

• #define FSL\_ECSPI\_FREERTOS\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 0)) ECSPI freertos driver version 2.0.0.

# **ECSPI RTOS Operation**

- status\_t ECSPI\_RTOS\_Init (ecspi\_rtos\_handle\_t \*handle, ECSPI\_Type \*base, const ecspi\_master\_config\_t \*masterConfig, uint32\_t srcClock\_Hz)
   Initializes ECSPI.
- status\_t ECSPI\_RTOS\_Deinit (ecspi\_rtos\_handle\_t \*handle)

  Deinitializes the ECSPI.
- status\_t ECSPI\_RTOS\_Transfer (ecspi\_rtos\_handle\_t \*handle, ecspi\_transfer\_t \*transfer)

  \*Performs ECSPI transfer.

# 6.3.2 Macro Definition Documentation

# 6.3.2.1 #define FSL ECSPI FREERTOS DRIVER VERSION (MAKE VERSION(2, 0, 0))

# 6.3.3 Function Documentation

# 6.3.3.1 status\_t ECSPI\_RTOS\_Init ( ecspi\_rtos\_handle\_t \* handle, ECSPI\_Type \* base, const ecspi\_master\_config\_t \* masterConfig, uint32\_t srcClock\_Hz )

This function initializes the ECSPI module and related RTOS context.

### **Parameters**

| handle       | The RTOS ECSPI handle, the pointer to an allocated space for RTOS context. |
|--------------|----------------------------------------------------------------------------|
| base         | The pointer base address of the ECSPI instance to initialize.              |
| masterConfig | Configuration structure to set-up ECSPI in master mode.                    |
| srcClock_Hz  | Frequency of input clock of the ECSPI module.                              |

#### Returns

status of the operation.

# 6.3.3.2 status\_t ECSPI\_RTOS\_Deinit ( ecspi\_rtos\_handle\_t \* handle )

This function deinitializes the ECSPI module and related RTOS context.

# **ECSPI FreeRTOS Driver**

# Parameters

| handle | The RTOS ECSPI handle. |
|--------|------------------------|
|--------|------------------------|

# 6.3.3.3 status\_t ECSPI\_RTOS\_Transfer ( ecspi\_rtos\_handle\_t \* handle, ecspi\_transfer\_t \* transfer )

This function performs an ECSPI transfer according to data given in the transfer structure.

# **Parameters**

| handle   | The RTOS ECSPI handle.                        |
|----------|-----------------------------------------------|
| transfer | Structure specifying the transfer parameters. |

# Returns

status of the operation.

# Chapter 7

# **GPT: General Purpose Timer**

# 7.1 Overview

The MCUXpresso SDK provides a driver for the General Purpose Timer (GPT) of MCUXpresso SDK devices.

# 7.2 Function groups

The gpt driver supports the generation of PWM signals, input capture, and setting up the timer match conditions.

# 7.2.1 Initialization and deinitialization

The function GPT\_Init() initializes the gpt with specified configurations. The function GPT\_GetDefault-Config() gets the default configurations. The initialization function configures the restart/free-run mode and input selection when running.

The function GPT\_Deinit() stops the timer and turns off the module clock.

# 7.3 Typical use case

# 7.3.1 GPT interrupt example

Set up a channel to trigger a periodic interrupt after every 1 second. Refer to the driver examples codes located at <SDK\_ROOT>/boards/<BOARD>/driver\_examples/gpt

# **Data Structures**

• struct gpt\_config\_t

Structure to configure the running mode. More...

# **Enumerations**

```
    enum gpt_clock_source_t {
        kGPT_ClockSource_Off = 0U,
        kGPT_ClockSource_Periph = 1U,
        kGPT_ClockSource_HighFreq = 2U,
        kGPT_ClockSource_Ext = 3U,
        kGPT_ClockSource_LowFreq = 4U,
        kGPT_ClockSource_Osc = 5U }
        List of clock sources.
```

MCUXpresso SDK API Reference Manual

# Typical use case

```
• enum gpt input capture channel t {
 kGPT_InputCapture_Channel1 = 0U,
 kGPT InputCapture Channel2 = 1U }
    List of input capture channel number.
enum gpt_input_operation_mode_t {
  kGPT InputOperation Disabled = 0U,
 kGPT_InputOperation_RiseEdge = 1U,
 kGPT_InputOperation_FallEdge = 2U,
 kGPT InputOperation BothEdge = 3U }
    List of input capture operation mode.
• enum gpt output compare channel t {
 kGPT_OutputCompare_Channel1 = 0U,
 kGPT_OutputCompare_Channel2 = 1U,
 kGPT OutputCompare Channel3 = 2U }
    List of output compare channel number.
enum gpt_output_operation_mode_t {
  kGPT_OutputOperation_Disconnected = 0U,
 kGPT_OutputOperation_Toggle = 1U,
 kGPT OutputOperation Clear = 2U,
 kGPT_OutputOperation_Set = 3U,
 kGPT_OutputOperation_Activelow = 4U }
    List of output compare operation mode.
enum gpt_interrupt_enable_t {
  kGPT OutputCompare1InterruptEnable = GPT IR OF1IE MASK,
 kGPT_OutputCompare2InterruptEnable = GPT_IR_OF2IE_MASK,
 kGPT_OutputCompare3InterruptEnable = GPT_IR_OF3IE_MASK,
 kGPT InputCapture1InterruptEnable = GPT IR IF1IE MASK,
 kGPT InputCapture2InterruptEnable = GPT IR IF2IE MASK,
 kGPT_RollOverFlagInterruptEnable = GPT_IR_ROVIE_MASK }
    List of GPT interrupts.
enum gpt_status_flag_t {
 kGPT OutputCompare1Flag = GPT SR OF1 MASK,
 kGPT_OutputCompare2Flag = GPT_SR_OF2_MASK,
 kGPT_OutputCompare3Flag = GPT_SR_OF3_MASK,
 kGPT_InputCapture1Flag = GPT_SR_IF1_MASK,
 kGPT_InputCapture2Flag = GPT_SR_IF2_MASK,
 kGPT_RollOverFlag = GPT_SR_ROV_MASK }
    Status flag.
```

# **Driver version**

• #define FSL\_GPT\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 0)) Version 2.0.0.

# Initialization and deinitialization

• void GPT\_Init (GPT\_Type \*base, const gpt\_config\_t \*initConfig)

Initialize GPT to reset state and initialize running mode.

• void GPT\_Deinit (GPT\_Type \*base)

Disables the module and gates the GPT clock.

• void GPT\_GetDefaultConfig (gpt\_config\_t \*config)

Fills in the GPT configuration structure with default settings.

# **Software Reset**

• static void GPT\_SoftwareReset (GPT\_Type \*base) Software reset of GPT module.

# **Clock source and frequency control**

- static void GPT\_SetClockSource (GPT\_Type \*base, gpt\_clock\_source\_t source)

  Set clock source of GPT.
- static gpt\_clock\_source\_t GPT\_GetClockSource (GPT\_Type \*base) Get clock source of GPT.
- static void GPT\_SetClockDivider (GPT\_Type \*base, uint32\_t divider)

  Set pre scaler of GPT.
- static uint32\_t GPT\_GetClockDivider (GPT\_Type \*base)

Get clock divider in GPT module.

• static void GPT\_SetOscClockDivider (GPT\_Type \*base, uint32\_t divider)

OSC 24M pre-scaler before selected by clock source.

• static uint32\_t GPT\_GetOscClockDivider (GPT\_Type \*base)

Get OSC 24M clock divider in GPT module.

# **Timer Start and Stop**

- static void GPT\_StartTimer (GPT\_Type \*base)

  Start GPT timer.
- static void GPT\_StopTimer (GPT\_Type \*base) Stop GPT timer.

# Read the timer period

• static uint32\_t GPT\_GetCurrentTimerCount (GPT\_Type \*base)

Reads the current GPT counting value.

# **GPT Input/Output Signal Control**

• static void GPT\_SetInputOperationMode (GPT\_Type \*base, gpt\_input\_capture\_channel\_t channel, gpt\_input\_operation\_mode\_t mode)

Set GPT operation mode of input capture channel.

• static gpt\_input\_operation\_mode\_t GPT\_GetInputOperationMode (GPT\_Type \*base, gpt\_input\_capture\_channel\_t channel)

Get GPT operation mode of input capture channel.

• static uint32\_t GPT\_GetInputCaptureValue (GPT\_Type \*base, gpt\_input\_capture\_channel\_t channel)

Get GPT input capture value of certain channel.

#### MCUXpresso SDK API Reference Manual

# **Data Structure Documentation**

• static void GPT\_SetOutputOperationMode (GPT\_Type \*base, gpt\_output\_compare\_channel\_t channel, gpt\_output\_operation\_mode\_t mode)

Set GPT operation mode of output compare channel.

• static gpt\_output\_operation\_mode\_t GPT\_GetOutputOperationMode (GPT\_Type \*base, gpt\_output\_compare\_channel\_t channel)

Get GPT operation mode of output compare channel.

• static void GPT\_SetOutputCompareValue (GPT\_Type \*base, gpt\_output\_compare\_channel\_t channel, uint32\_t value)

Set GPT output compare value of output compare channel.

• static uint32\_t GPT\_GetOutputCompareValue (GPT\_Type \*base, gpt\_output\_compare\_channel\_t channel)

Get GPT output compare value of output compare channel.

• static void GPT\_ForceOutput (GPT\_Type \*base, gpt\_output\_compare\_channel\_t channel)

Force GPT output action on output compare channel, ignoring comparator.

# **GPT Interrupt and Status Interface**

• static void GPT\_EnableInterrupts (GPT\_Type \*base, uint32\_t mask)

Enables the selected GPT interrupts.

• static void GPT\_DisableInterrupts (GPT\_Type \*base, uint32\_t mask)

Disables the selected GPT interrupts.

• static uint32\_t GPT\_GetEnabledInterrupts (GPT\_Type \*base)

Gets the enabled GPT interrupts.

# Status Interface

- static uint32\_t GPT\_GetStatusFlags (GPT\_Type \*base, gpt\_status\_flag\_t flags) Get GPT status flags.
- static void GPT\_ClearStatusFlags (GPT\_Type \*base, gpt\_status\_flag\_t flags) Clears the GPT status flags.

# 7.4 Data Structure Documentation

# 7.4.1 struct gpt\_config\_t

# **Data Fields**

• gpt\_clock\_source\_t clockSource

clock source for GPT module.

• uint32\_t divider

*clock divider (prescaler+1) from clock source to counter.* 

bool enableFreeRun

true: FreeRun mode, false: Restart mode.

• bool enableRunInWait

GPT enabled in wait mode.

• bool enableRunInStop

GPT enabled in stop mode.

bool enableRunInDoze

GPT enabled in doze mode.

# **Enumeration Type Documentation**

- bool enableRunInDbg
  - GPT enabled in debug mode.
- bool enableMode

```
true: counter reset to 0 when enabled; false: counter retain its value when enabled.
```

# 7.4.1.0.0.2 Field Documentation

- 7.4.1.0.0.2.1 gpt\_clock\_source\_t gpt config t::clockSource
- 7.4.1.0.0.2.2 uint32\_t gpt\_config\_t::divider
- 7.4.1.0.0.2.3 bool gpt config t::enableFreeRun
- 7.4.1.0.0.2.4 bool gpt config t::enableRunInWait
- 7.4.1.0.0.2.5 bool gpt\_config\_t::enableRunInStop
- 7.4.1.0.0.2.6 bool gpt\_config\_t::enableRunInDoze
- 7.4.1.0.0.2.7 bool gpt\_config\_t::enableRunInDbg
- 7.4.1.0.0.2.8 bool gpt\_config\_t::enableMode

# 7.5 Enumeration Type Documentation

# 7.5.1 enum gpt\_clock\_source\_t

Note

Actual number of clock sources is SoC dependent

#### Enumerator

```
kGPT_ClockSource_Off GPT Clock Source Off.
```

kGPT\_ClockSource\_Periph GPT Clock Source from Peripheral Clock.

kGPT\_ClockSource\_HighFreq GPT Clock Source from High Frequency Reference Clock.

kGPT ClockSource Ext GPT Clock Source from external pin.

kGPT\_ClockSource\_LowFreq GPT Clock Source from Low Frequency Reference Clock.

kGPT\_ClockSource\_Osc GPT Clock Source from Crystal oscillator.

# 7.5.2 enum gpt\_input\_capture\_channel\_t

# Enumerator

```
kGPT_InputCapture_Channel1 GPT Input Capture Channel1.kGPT_InputCapture_Channel2 GPT Input Capture Channel2.
```

# MCUXpresso SDK API Reference Manual

# **Enumeration Type Documentation**

# 7.5.3 enum gpt\_input\_operation\_mode\_t

### Enumerator

```
    kGPT_InputOperation_Disabled
    kGPT_InputOperation_RiseEdge
    kGPT_InputOperation_FallEdge
    Capture on falling edge of input pin.
    kGPT_InputOperation_BothEdge
    Capture on both edges of input pin.
```

# 7.5.4 enum gpt\_output\_compare\_channel\_t

### Enumerator

```
kGPT_OutputCompare_Channel1 Output Compare Channel1.kGPT_OutputCompare_Channel2 Output Compare Channel2.kGPT_OutputCompare_Channel3 Output Compare Channel3.
```

# 7.5.5 enum gpt\_output\_operation\_mode\_t

### Enumerator

```
kGPT_OutputOperation_Disconnected Don't change output pin.
kGPT_OutputOperation_Toggle Toggle output pin.
kGPT_OutputOperation_Clear Set output pin low.
kGPT_OutputOperation_Set Set output pin high.
kGPT_OutputOperation_Activelow Generate a active low pulse on output pin.
```

# 7.5.6 enum gpt\_interrupt\_enable\_t

### Enumerator

```
kGPT_OutputCompare1InterruptEnable
Output Compare Channel1 interrupt enable.
kGPT_OutputCompare2InterruptEnable
Output Compare Channel2 interrupt enable.
kGPT_OutputCompare3InterruptEnable
Output Compare Channel3 interrupt enable.
kGPT_InputCapture1InterruptEnable
Input Capture Channel1 interrupt enable.
kGPT_InputCapture2InterruptEnable
Input Capture Channel1 interrupt enable.
kGPT_RollOverFlagInterruptEnable
Counter rolled over interrupt enable.
```

# 7.5.7 enum gpt\_status\_flag\_t

### Enumerator

```
    kGPT_OutputCompare1Flag
    Output compare channel 1 event.
    kGPT_OutputCompare2Flag
    Output compare channel 2 event.
    kGPT_InputCapture1Flag
    Input Capture channel 1 event.
    kGPT_InputCapture2Flag
    Input Capture channel 2 event.
    kGPT_RollOverFlag
    Counter reaches maximum value and rolled over to 0 event.
```

# 7.6 Function Documentation

# 7.6.1 void GPT\_Init ( GPT\_Type \* base, const gpt\_config\_t \* initConfig )

### **Parameters**

| base       | GPT peripheral base address.    |
|------------|---------------------------------|
| initConfig | GPT mode setting configuration. |

# 7.6.2 void GPT Deinit ( GPT Type \* base )

# **Parameters**

| base | GPT peripheral base address. |
|------|------------------------------|

# 7.6.3 void GPT\_GetDefaultConfig ( $gpt\_config\_t * config$ )

The default values are:

```
* config->clockSource = kGPT_ClockSource_Periph;
* config->divider = 1U;
* config->enableRunInStop = true;
* config->enableRunInWait = true;
* config->enableRunInDoze = false;
* config->enableRunInDbg = false;
* config->enableFreeRun = true;
* config->enableMode = true;
*
```

# **Function Documentation**

# **Parameters**

| config | Pointer to the user configuration structure. |
|--------|----------------------------------------------|
|--------|----------------------------------------------|

# 7.6.4 static void GPT\_SoftwareReset ( GPT\_Type \* base ) [inline], [static]

# **Parameters**

| base | GPT peripheral base address. |
|------|------------------------------|
|------|------------------------------|

# 7.6.5 static void GPT\_SetClockSource ( GPT\_Type \* base, gpt\_clock\_source\_t source ) [inline], [static]

#### **Parameters**

| base   | GPT peripheral base address.                                                                       |
|--------|----------------------------------------------------------------------------------------------------|
| source | Clock source (see <a href="mailto:gpt_clock_source_t">gpt_clock_source_t</a> typedef enumeration). |

# 7.6.6 static gpt\_clock\_source\_t GPT\_GetClockSource ( GPT\_Type \* base ) [inline], [static]

### **Parameters**

| base | GPT peripheral base address. |
|------|------------------------------|
|------|------------------------------|

# Returns

clock source (see <a href="mailto:gpt\_clock\_source\_t">gpt\_clock\_source\_t</a> typedef enumeration).

# 7.6.7 static void GPT\_SetClockDivider ( GPT\_Type \* base, uint32\_t divider ) [inline], [static]

#### **Parameters**

| base    | GPT peripheral base address. |
|---------|------------------------------|
| divider | Divider of GPT (1-4096).     |

# 7.6.8 static uint32\_t GPT\_GetClockDivider ( GPT\_Type \* base ) [inline], [static]

# **Parameters**

| _ |      |                              |
|---|------|------------------------------|
|   | base | GPT peripheral base address. |

### Returns

clock divider in GPT module (1-4096).

# 7.6.9 static void GPT\_SetOscClockDivider ( GPT\_Type \* base, uint32\_t divider ) [inline], [static]

# **Parameters**

| base    | GPT peripheral base address. |
|---------|------------------------------|
| divider | OSC Divider(1-16).           |

# 7.6.10 static uint32\_t GPT\_GetOscClockDivider ( GPT\_Type \* base ) [inline], [static]

# **Parameters**

| base | GPT peripheral base address. |
|------|------------------------------|
|------|------------------------------|

### Returns

OSC clock divider in GPT module (1-16).

# 7.6.11 static void GPT StartTimer ( GPT Type \* base ) [inline], [static]

MCUXpresso SDK API Reference Manual

# **Function Documentation**

### **Parameters**

| base | GPT peripheral base address. |
|------|------------------------------|
|------|------------------------------|

# 7.6.12 static void GPT\_StopTimer( GPT\_Type \* base ) [inline], [static]

### **Parameters**

| base | GPT peripheral base address. |
|------|------------------------------|
|------|------------------------------|

# 7.6.13 static uint32\_t GPT\_GetCurrentTimerCount ( GPT\_Type \* base ) [inline], [static]

### **Parameters**

| base | GPT peripheral base address. |
|------|------------------------------|
|------|------------------------------|

# Returns

Current GPT counter value.

# 7.6.14 static void GPT\_SetInputOperationMode ( GPT\_Type \* base, gpt\_input\_capture\_channel\_t channel, gpt\_input\_operation\_mode\_t mode ) [inline], [static]

### **Parameters**

| base    | GPT peripheral base address.                                                  |
|---------|-------------------------------------------------------------------------------|
| channel | GPT capture channel (see gpt_input_capture_channel_t typedef enumeration).    |
| mode    | GPT input capture operation mode (see gpt_input_operation_mode_t typedef enu- |
|         | meration).                                                                    |

# 7.6.15 static gpt\_input\_operation\_mode\_t GPT\_GetInputOperationMode ( GPT\_Type \* base, gpt\_input\_capture\_channel\_t channel ) [inline], [static]

# MCUXpresso SDK API Reference Manual

89

### **Parameters**

| base    | GPT peripheral base address.                                               |
|---------|----------------------------------------------------------------------------|
| channel | GPT capture channel (see gpt_input_capture_channel_t typedef enumeration). |

### Returns

GPT input capture operation mode (see <a href="mailto:gpt\_input\_operation\_mode\_t">gpt\_input\_operation\_mode\_t</a> typedef enumeration).

# 7.6.16 static uint32\_t GPT\_GetInputCaptureValue ( GPT\_Type \* base, gpt\_input\_capture\_channel\_t channel ) [inline], [static]

# **Parameters**

| base    | GPT peripheral base address.                                               |
|---------|----------------------------------------------------------------------------|
| channel | GPT capture channel (see gpt_input_capture_channel_t typedef enumeration). |

### Returns

GPT input capture value.

# 7.6.17 static void GPT\_SetOutputOperationMode ( GPT\_Type \* base, gpt\_output\_compare\_channel\_t channel, gpt\_output\_operation\_mode\_t mode ) [inline], [static]

### **Parameters**

| base    | GPT peripheral base address.                                                                                                         |
|---------|--------------------------------------------------------------------------------------------------------------------------------------|
| channel | GPT output compare channel (see <a href="mailto:gpt_output_compare_channel_t">gpt_output_compare_channel_t</a> typedef enumeration). |
| mode    | GPT output operation mode (see gpt_output_operation_mode_t typedef enumeration).                                                     |

# 7.6.18 static gpt\_output\_operation\_mode\_t GPT\_GetOutputOperationMode ( GPT\_Type \* base, gpt\_output\_compare\_channel\_t channel ) [inline], [static]

# **Function Documentation**

### **Parameters**

| base    | GPT peripheral base address.                                                       |
|---------|------------------------------------------------------------------------------------|
| channel | GPT output compare channel (see gpt_output_compare_channel_t typedef enumeration). |

# Returns

GPT output operation mode (see <a href="mailto:gpt\_output\_operation\_mode\_t">gpt\_output\_operation\_mode\_t</a> typedef enumeration).

# 7.6.19 static void GPT\_SetOutputCompareValue ( GPT\_Type \* base, gpt\_output\_compare\_channel\_t channel, uint32\_t value ) [inline], [static]

### **Parameters**

| base    | GPT peripheral base address.                                                  |
|---------|-------------------------------------------------------------------------------|
| channel | GPT output compare channel (see gpt_output_compare_channel_t typedef enumera- |
|         | tion).                                                                        |
| value   | GPT output compare value.                                                     |

# 7.6.20 static uint32\_t GPT\_GetOutputCompareValue ( GPT\_Type \* base, gpt\_output\_compare\_channel\_t channel ) [inline], [static]

# **Parameters**

| base    | GPT peripheral base address.                                                  |
|---------|-------------------------------------------------------------------------------|
| channel | GPT output compare channel (see gpt_output_compare_channel_t typedef enumera- |
|         | tion).                                                                        |

### Returns

GPT output compare value.

# 7.6.21 static void GPT\_ForceOutput ( GPT\_Type \* base, gpt\_output\_compare\_channel\_t channel) [inline], [static]

#### **Parameters**

| base    | GPT peripheral base address.                                                       |
|---------|------------------------------------------------------------------------------------|
| channel | GPT output compare channel (see gpt_output_compare_channel_t typedef enumeration). |

# 7.6.22 static void GPT\_EnableInterrupts ( GPT\_Type \* base, uint32\_t mask ) [inline], [static]

## **Parameters**

| base | GPT peripheral base address.                                                                        |
|------|-----------------------------------------------------------------------------------------------------|
|      | The interrupts to enable. This is a logical OR of members of the enumeration gpt_interrupt_enable_t |

# 7.6.23 static void GPT\_DisableInterrupts ( GPT\_Type \* base, uint32\_t mask ) [inline], [static]

## **Parameters**

| base | GPT peripheral base address                                                                          |
|------|------------------------------------------------------------------------------------------------------|
| mask | The interrupts to disable. This is a logical OR of members of the enumeration gpt_interrupt_enable_t |

# 7.6.24 static uint32\_t GPT\_GetEnabledInterrupts ( GPT\_Type \* base ) [inline], [static]

## **Parameters**

| base | GPT peripheral base address |
|------|-----------------------------|
|------|-----------------------------|

## Returns

The enabled interrupts. This is the logical OR of members of the enumeration gpt\_interrupt\_enable\_t

MCUXpresso SDK API Reference Manual

## **Function Documentation**

7.6.25 static uint32\_t GPT\_GetStatusFlags ( GPT\_Type \* base, gpt\_status\_flag\_t flags ) [inline], [static]

93

## Parameters

| base  | GPT peripheral base address.                                     |
|-------|------------------------------------------------------------------|
| flags | GPT status flag mask (see gpt_status_flag_t for bit definition). |

## Returns

GPT status, each bit represents one status flag.

## 7.6.26 static void GPT\_ClearStatusFlags ( GPT\_Type \* base, gpt\_status\_flag\_t flags ) [inline], [static]

## Parameters

| base  | GPT peripheral base address.                                     |
|-------|------------------------------------------------------------------|
| flags | GPT status flag mask (see gpt_status_flag_t for bit definition). |

MCUXpresso SDK API Reference Manual

**Function Documentation** 

## **Chapter 8**

**GPIO:** General-Purpose Input/Output Driver

## 8.1 Overview

## **Modules**

• GPIO Driver

## **GPIO Driver**

## 8.2 GPIO Driver

## 8.2.1 Overview

The MCUXpresso SDK provides a peripheral driver for the General-Purpose Input/Output (GPIO) module of MCUXpresso SDK devices.

## 8.2.2 Typical use case

## 8.2.2.1 Input Operation

Refer to the driver examples codes located at <SDK\_ROOT>/boards/<BOARD>/driver\_examples/gpio

## **Data Structures**

• struct gpio\_pin\_config\_t

GPIO Init structure definition. More...

## **Enumerations**

```
    enum gpio_pin_direction_t {
        kGPIO_DigitalInput = 0U,
        kGPIO_DigitalOutput = 1U }
        GPIO direction definition.
    enum gpio_interrupt_mode_t {
        kGPIO_NoIntmode = 0U,
        kGPIO_IntLowLevel = 1U,
        kGPIO_IntHighLevel = 2U,
        kGPIO_IntRisingEdge = 3U,
        kGPIO_IntFallingEdge = 4U,
        kGPIO_IntRisingOrFallingEdge = 5U }
        GPIO interrupt mode definition.
```

## **Driver version**

• #define FSL\_GPIO\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 1)) GPIO driver version 2.0.1.

## **GPIO Initialization and Configuration functions**

• void GPIO\_PinInit (GPIO\_Type \*base, uint32\_t pin, const gpio\_pin\_config\_t \*Config)

Initializes the GPIO peripheral according to the specified parameters in the initConfig.

## **GPIO Reads and Write Functions**

• void GPIO\_PinWrite (GPIO\_Type \*base, uint32\_t pin, uint8\_t output)

*Sets the output level of the individual GPIO pin to logic 1 or 0.* 

• static void GPIO\_WritePinOutput (GPIO\_Type \*base, uint32\_t pin, uint8\_t output)

*Sets the output level of the individual GPIO pin to logic 1 or 0.* 

• static void GPIO\_PortSet (GPIO\_Type \*base, uint32\_t mask)

*Sets the output level of the multiple GPIO pins to the logic 1.* 

• static void GPIO\_SetPinsOutput (GPIO\_Type \*base, uint32\_t mask)

*Sets the output level of the multiple GPIO pins to the logic 1.* 

• static void GPIO\_PortClear (GPIO\_Type \*base, uint32\_t mask)

Sets the output level of the multiple GPIO pins to the logic 0.

• static void GPIO\_ClearPinsOutput (GPIO\_Type \*base, uint32\_t mask)

Sets the output level of the multiple GPIO pins to the logic 0.

• static void GPIO\_PortToggle (GPIO\_Type \*base, uint32\_t mask)

Reverses the current output logic of the multiple GPIO pins.

• static uint32\_t GPIO\_PinRead (GPIO\_Type \*base, uint32\_t pin)

Reads the current input value of the GPIO port.

• static uint32\_t GPIO\_ReadPinInput (GPIO\_Type \*base, uint32\_t pin)

Reads the current input value of the GPIO port.

### **GPIO Reads Pad Status Functions**

• static uint8\_t GPIO\_PinReadPadStatus (GPIO\_Type \*base, uint32\_t pin)

Reads the current GPIO pin pad status.

• static uint8\_t GPIO\_ReadPadStatus (GPIO\_Type \*base, uint32\_t pin)

Reads the current GPIO pin pad status.

## Interrupts and flags management functions

• void GPIO\_PinSetInterruptConfig (GPIO\_Type \*base, uint32\_t pin, gpio\_interrupt\_mode\_t pin-InterruptMode)

Sets the current pin interrupt mode.

• static void GPIO\_SetPinInterruptConfig (GPIO\_Type \*base, uint32\_t pin, gpio\_interrupt\_mode\_t pinInterruptMode)

*Sets the current pin interrupt mode.* 

• static void GPIO\_PortEnableInterrupts (GPIO\_Type \*base, uint32\_t mask)

Enables the specific pin interrupt.

• static void GPIO\_EnableInterrupts (GPIO\_Type \*base, uint32\_t mask)

*Enables the specific pin interrupt.* 

• static void GPIO\_PortDisableInterrupts (GPIO\_Type \*base, uint32\_t mask)

Disables the specific pin interrupt.

• static void GPIO\_DisableInterrupts (GPIO\_Type \*base, uint32\_t mask)

Disables the specific pin interrupt.

• static uint32\_t GPIO\_PortGetInterruptFlags (GPIO\_Type \*base)

Reads individual pin interrupt status.

• static uint32 t GPIO GetPinsInterruptFlags (GPIO Type \*base)

Reads individual pin interrupt status.

#### MCUXpresso SDK API Reference Manual

## **GPIO Driver**

- static void GPIO\_PortClearInterruptFlags (GPIO\_Type \*base, uint32\_t mask) Clears pin interrupt flag.
- static void GPIO\_ClearPinsInterruptFlags (GPIO\_Type \*base, uint32\_t mask) Clears pin interrupt flag.

## 8.2.3 Data Structure Documentation

## 8.2.3.1 struct gpio\_pin\_config\_t

#### **Data Fields**

- gpio\_pin\_direction\_t direction Specifies the pin direction.
- uint8\_t outputLogic

Set a default output logic, which has no use in input.

• gpio\_interrupt\_mode\_t interruptMode

Specifies the pin interrupt mode, a value of gpio\_interrupt\_mode\_t.

#### 8.2.3.1.0.3 Field Documentation

- 8.2.3.1.0.3.1 gpio\_pin\_direction\_t gpio\_pin\_config\_t::direction
- 8.2.3.1.0.3.2 gpio\_interrupt\_mode\_t gpio\_pin\_config\_t::interruptMode
- 8.2.4 Macro Definition Documentation
- 8.2.4.1 #define FSL\_GPIO\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 1))

## 8.2.5 Enumeration Type Documentation

## 8.2.5.1 enum gpio\_pin\_direction\_t

#### Enumerator

kGPIO\_DigitalInput Set current pin as digital input.kGPIO\_DigitalOutput Set current pin as digital output.

## 8.2.5.2 enum gpio\_interrupt\_mode\_t

#### Enumerator

kGPIO\_NoIntmode Set current pin general IO functionality.kGPIO\_IntLowLevel Set current pin interrupt is low-level sensitive.kGPIO\_IntHighLevel Set current pin interrupt is high-level sensitive.

*kGPIO\_IntRisingEdge* Set current pin interrupt is rising-edge sensitive.

#### MCUXpresso SDK API Reference Manual

kGPIO\_IntFallingEdge Set current pin interrupt is falling-edge sensitive.kGPIO\_IntRisingOrFallingEdge Enable the edge select bit to override the ICR register's configuration.

## 8.2.6 Function Documentation

## 8.2.6.1 void GPIO\_PinInit ( GPIO\_Type \* base, uint32\_t pin, const gpio\_pin\_config\_t \* Config )

## Parameters

| base       | GPIO base pointer.                                                                    |
|------------|---------------------------------------------------------------------------------------|
| pin        | Specifies the pin number                                                              |
| initConfig | pointer to a gpio_pin_config_t structure that contains the configuration information. |

## 8.2.6.2 void GPIO\_PinWrite ( GPIO\_Type \* base, uint32\_t pin, uint8\_t output )

## **Parameters**

| base   | GPIO base pointer.                                                                                                                                           |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pin    | GPIO port pin number.                                                                                                                                        |
| output | <ul> <li>GPIOpin output logic level.</li> <li>0: corresponding pin output low-logic level.</li> <li>1: corresponding pin output high-logic level.</li> </ul> |

- 8.2.6.3 static void GPIO\_WritePinOutput ( GPIO\_Type \* base, uint32\_t pin, uint8\_t output ) [inline], [static]

Parameters

MCUXpresso SDK API Reference Manual

## **GPIO Driver**

| base | GPIO peripheral base pointer (GPIO1, GPIO2, GPIO3, and so on.) |
|------|----------------------------------------------------------------|
| mask | GPIO pin number macro                                          |

# 8.2.6.5 static void GPIO\_SetPinsOutput ( GPIO\_Type \* base, uint32\_t mask ) [inline], [static]

# 8.2.6.6 static void GPIO\_PortClear ( GPIO\_Type \* base, uint32\_t mask ) [inline], [static]

#### **Parameters**

| base | GPIO peripheral base pointer (GPIO1, GPIO2, GPIO3, and so on.) |
|------|----------------------------------------------------------------|
| mask | GPIO pin number macro                                          |

# 8.2.6.7 static void GPIO\_ClearPinsOutput ( GPIO\_Type \* base, uint32\_t mask ) [inline], [static]

## 

## Parameters

| base | GPIO peripheral base pointer (GPIO1, GPIO2, GPIO3, and so on.) |
|------|----------------------------------------------------------------|
| mask | GPIO pin number macro                                          |

## 8.2.6.9 static uint32\_t GPIO\_PinRead ( GPIO\_Type \* base, uint32\_t pin ) [inline], [static]

## Parameters

| base | GPIO base pointer.    |
|------|-----------------------|
| pin  | GPIO port pin number. |

## Return values

MCUXpresso SDK API Reference Manual

| GPIO | port input value. |
|------|-------------------|
|------|-------------------|

- 8.2.6.10 static uint32\_t GPIO\_ReadPinInput ( GPIO\_Type \* base, uint32\_t pin ) [inline], [static]
- 8.2.6.11 static uint8\_t GPIO\_PinReadPadStatus ( GPIO\_Type \* base, uint32\_t pin ) [inline], [static]

## **Parameters**

| base | GPIO base pointer.    |
|------|-----------------------|
| pin  | GPIO port pin number. |

## Return values

| GPIO | pin pad status value. |
|------|-----------------------|
|      | 1 1                   |

- 8.2.6.12 static uint8\_t GPIO\_ReadPadStatus ( GPIO\_Type \* base, uint32\_t pin ) [inline], [static]
- 8.2.6.13 void GPIO\_PinSetInterruptConfig ( GPIO\_Type \* base, uint32\_t pin, gpio\_interrupt\_mode\_t pinInterruptMode )

#### **Parameters**

| base | GPIO base pointer.                                                                         |
|------|--------------------------------------------------------------------------------------------|
| pin  | GPIO port pin number.                                                                      |
| • •  | pointer to a gpio_interrupt_mode_t structure that contains the interrupt mode information. |

- 8.2.6.14 static void GPIO\_SetPinInterruptConfig ( GPIO\_Type \* base, uint32\_t pin, gpio\_interrupt\_mode\_t pinInterruptMode ) [inline], [static]
- 8.2.6.15 static void GPIO\_PortEnableInterrupts ( GPIO\_Type \* base, uint32\_t mask ) [inline], [static]

## **GPIO Driver**

#### **Parameters**

| base | GPIO base pointer.     |
|------|------------------------|
| mask | GPIO pin number macro. |

## 8.2.6.16 static void GPIO\_EnableInterrupts ( GPIO\_Type \* base, uint32\_t mask ) [inline], [static]

#### Parameters

| base | GPIO base pointer.     |
|------|------------------------|
| mask | GPIO pin number macro. |

## 8.2.6.17 static void GPIO\_PortDisableInterrupts ( GPIO\_Type \* base, uint32\_t mask ) [inline], [static]

#### **Parameters**

| base | GPIO base pointer.     |
|------|------------------------|
| mask | GPIO pin number macro. |

# 8.2.6.18 static void GPIO\_DisableInterrupts ( GPIO\_Type \* base, uint32\_t mask ) [inline], [static]

# 8.2.6.19 static uint32\_t GPIO\_PortGetInterruptFlags ( GPIO\_Type \* base ) [inline], [static]

## Parameters

| base | GPIO base pointer. |
|------|--------------------|

## Return values

| current | pin interrupt status flag. |
|---------|----------------------------|
|---------|----------------------------|

## 8.2.6.20 static uint32\_t GPIO\_GetPinsInterruptFlags ( GPIO\_Type \* base ) [inline], [static]

## **MCUXpresso SDK API Reference Manual**

#### **Parameters**

| base | GPIO base pointer. |
|------|--------------------|
|------|--------------------|

## Return values

| current | pin interrupt status flag. |
|---------|----------------------------|

# 8.2.6.21 static void GPIO\_PortClearInterruptFlags ( GPIO\_Type \* base, uint32\_t mask ) [inline], [static]

Status flags are cleared by writing a 1 to the corresponding bit position.

## **Parameters**

| base | GPIO base pointer.     |
|------|------------------------|
| mask | GPIO pin number macro. |

# 8.2.6.22 static void GPIO\_ClearPinsInterruptFlags ( GPIO\_Type \* base, uint32\_t mask ) [inline], [static]

Status flags are cleared by writing a 1 to the corresponding bit position.

## **Parameters**

| base | GPIO base pointer.     |
|------|------------------------|
| mask | GPIO pin number macro. |

**GPIO Driver** 

## **Chapter 9**

**I2C: Inter-Integrated Circuit Driver** 

## 9.1 Overview

## **Modules**

- I2C Driver
- I2C FreeRTOS Driver

## 9.2 I2C Driver

## 9.2.1 Overview

The MCUXpresso SDK provides a peripheral driver for the Inter-Integrated Circuit (I2C) module of MC-UXpresso SDK devices.

The I2C driver includes functional APIs and transactional APIs.

Functional APIs target the low-level APIs. Functional APIs can be used for the I2C master/slave initialization/configuration/operation for optimization/customization purpose. Using the functional APIs requires knowing the I2C master peripheral and how to organize functional APIs to meet the application requirements. The I2C functional operation groups provide the functional APIs set.

Transactional APIs target the high-level APIs. The transactional APIs can be used to enable the peripheral quickly and also in the application if the code size and performance of transactional APIs satisfy the requirements. If the code size and performance are critical requirements, see the transactional API implementation and write custom code using the functional APIs or accessing the hardware registers.

Transactional APIs support asynchronous transfer. This means that the functions I2C\_MasterTransfer-NonBlocking() set up the interrupt non-blocking transfer. When the transfer completes, the upper layer is notified through a callback function with the status.

## 9.2.2 Typical use case

## 9.2.2.1 Master Operation in functional method

Refer to the driver examples codes located at <SDK\_ROOT>/boards/<BOARD>/driver\_examples/i2c

## 9.2.2.2 Master Operation in interrupt transactional method

Refer to the driver examples codes located at <SDK\_ROOT>/boards/<BOARD>/driver\_examples/i2c

## 9.2.2.3 Slave Operation in functional method

Refer to the driver examples codes located at <SDK\_ROOT>/boards/<BOARD>/driver\_examples/i2c

## 9.2.2.4 Slave Operation in interrupt transactional method

Refer to the driver examples codes located at <SDK\_ROOT>/boards/<BOARD>/driver\_examples/i2c

## **Data Structures**

• struct i2c master config t

```
    12C master user configuration. More...
    struct i2c_master_transfer_t
    12C master transfer structure. More...
    struct i2c_master_handle_t
    12C master handle structure. More...
    struct i2c_slave_config_t
    12C slave user configuration. More...
    struct i2c_slave_transfer_t
    12C slave transfer structure. More...
    struct i2c_slave_handle_t
    12C slave handle structure. More...
```

## **Macros**

#define I2C\_WAIT\_TIMEOUT 0U /\* Define to zero means keep waiting until the flag is assert/deassert. \*/

Timeout times for waiting flag.

## **Typedefs**

- typedef void(\* i2c\_master\_transfer\_callback\_t )(I2C\_Type \*base, i2c\_master\_handle\_t \*handle, status\_t status, void \*userData)
   I2C master transfer callback typedef.
- typedef void(\* i2c\_slave\_transfer\_callback\_t )(I2C\_Type \*base, i2c\_slave\_transfer\_t \*xfer, void \*userData)

I2C slave transfer callback typedef.

## **Enumerations**

```
• enum i2c status {
 kStatus_I2C_Busy = MAKE_STATUS(kStatusGroup_I2C, 0),
 kStatus I2C Idle = MAKE STATUS(kStatusGroup I2C, 1),
 kStatus_I2C_Nak = MAKE_STATUS(kStatusGroup_I2C, 2),
 kStatus I2C ArbitrationLost = MAKE STATUS(kStatusGroup I2C, 3),
 kStatus I2C Timeout = MAKE STATUS(kStatusGroup I2C, 4),
 kStatus_I2C_Addr_Nak = MAKE_STATUS(kStatusGroup_I2C, 5) }
    I2C status return codes.
enum _i2c_flags {
 kI2C_ReceiveNakFlag = I2C_I2SR_RXAK_MASK,
 kI2C_IntPendingFlag = I2C_I2SR_IIF_MASK,
 kI2C_TransferDirectionFlag = I2C_I2SR_SRW_MASK,
 kI2C_ArbitrationLostFlag = I2C_I2SR_IAL_MASK,
 kI2C_BusBusyFlag = I2C_I2SR_IBB_MASK,
 kI2C_AddressMatchFlag = I2C_I2SR_IAAS_MASK,
 kI2C_TransferCompleteFlag = I2C_I2SR_ICF_MASK }
```

## MCUXpresso SDK API Reference Manual

```
I2C peripheral flags.
• enum i2c interrupt enable { kI2C GlobalInterruptEnable = I2C I2CR IIEN MASK }
    I2C feature interrupt source.
enum i2c_direction_t {
  kI2C Write = 0x0U,
 kI2C Read = 0x1U }
     The direction of master and slave transfers.
enum _i2c_master_transfer_flags {
  kI2C_TransferDefaultFlag = 0x0U,
  kI2C TransferNoStartFlag = 0x1U,
 kI2C_TransferRepeatedStartFlag = 0x2U,
 kI2C TransferNoStopFlag = 0x4U }
    I2C transfer control flag.
enum i2c_slave_transfer_event_t {
  kI2C SlaveAddressMatchEvent = 0x01U,
 kI2C_SlaveTransmitEvent = 0x02U,
 kI2C_SlaveReceiveEvent = 0x04U,
 kI2C_SlaveTransmitAckEvent = 0x08U,
 kI2C_SlaveCompletionEvent = 0x20U,
 kI2C_SlaveAllEvents }
    Set of events sent to the callback for nonblocking slave transfers.
```

## **Driver version**

• #define FSL\_I2C\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 4)) *I2C driver version 2.0.4.* 

#### Initialization and deinitialization

```
    void I2C_MasterInit (I2C_Type *base, const i2c_master_config_t *masterConfig, uint32_t src-Clock_Hz)
        Initializes the I2C peripheral.
    void I2C_MasterDeinit (I2C_Type *base)
        De-initializes the I2C master peripheral.
```

• void I2C\_MasterGetDefaultConfig (i2c\_master\_config\_t \*masterConfig)

Sets the I2C master configuration structure to default values.

oid I2C SlaveInit (I2C Type \*base, const i2c slave config t \*slaveConfig)

• void I2C\_SlaveInit (I2C\_Type \*base, const i2c\_slave\_config\_t \*slaveConfig)

Initializes the I2C peripheral.

• void I2C\_SlaveDeinit (I2C\_Type \*base)

De-initializes the I2C slave peripheral.

• void I2C\_SlaveGetDefaultConfig (i2c\_slave\_config\_t \*slaveConfig)

Sets the I2C slave configuration structure to default values.

• static void <a href="I2C\_Enable">I2C\_Enable</a> (I2C\_Type \*base, bool enable)

Enables or disabless the I2C peripheral operation.

## **Status**

• static uint32\_t I2C\_MasterGetStatusFlags (I2C\_Type \*base)

Gets the I2C status flags.

- static void I2C\_MasterClearStatusFlags (I2C\_Type \*base, uint32\_t statusMask) Clears the I2C status flag state.
- static uint32\_t I2C\_SlaveGetStatusFlags (I2C\_Type \*base) Gets the I2C status flags.
- static void I2C\_SlaveClearStatusFlags (I2C\_Type \*base, uint32\_t statusMask) Clears the I2C status flag state.

## Interrupts

• void I2C\_EnableInterrupts (I2C\_Type \*base, uint32\_t mask)

Enables I2C interrupt requests.

• void I2C\_DisableInterrupts (I2C\_Type \*base, uint32\_t mask)

Disables I2C interrupt requests.

## **Bus Operations**

- void I2C\_MasterSetBaudRate (I2C\_Type \*base, uint32\_t baudRate\_Bps, uint32\_t srcClock\_Hz) Sets the I2C master transfer baud rate.
- status\_t I2C\_MasterStart (I2C\_Type \*base, uint8\_t address, i2c\_direction\_t direction) Sends a START on the I2C bus.
- status\_t I2C\_MasterStop (I2C\_Type \*base)

Sends a STOP signal on the I2C bus.

- status\_t I2C\_MasterRepeatedStart (I2C\_Type \*base, uint8\_t address, i2c\_direction\_t direction)

  Sends a REPEATED START on the I2C bus.
- status\_t I2C\_MasterWriteBlocking (I2C\_Type \*base, const uint8\_t \*txBuff, size\_t txSize, uint32\_t flags)

Performs a polling send transaction on the I2C bus.

- status\_t I2C\_MasterReadBlocking (I2C\_Type \*base, uint8\_t \*rxBuff, size\_t rxSize, uint32\_t flags)

  Performs a polling receive transaction on the I2C bus.
- status\_t I2C\_SlaveWriteBlocking (I2C\_Type \*base, const uint8\_t \*txBuff, size\_t txSize)

  Performs a polling send transaction on the I2C bus.
- status\_t I2C\_SlaveReadBlocking (I2C\_Type \*base, uint8\_t \*rxBuff, size\_t rxSize)

  Performs a polling receive transaction on the I2C bus.
- status\_t I2C\_MasterTransferBlocking (I2C\_Type \*base, i2c\_master\_transfer\_t \*xfer) Performs a master polling transfer on the I2C bus.

#### **Transactional**

- void I2C\_MasterTransferCreateHandle (I2C\_Type \*base, i2c\_master\_handle\_t \*handle, i2c\_master\_transfer\_callback\_t callback, void \*userData)
  - *Initializes the I2C handle which is used in transactional functions.*
- status\_t I2C\_MasterTransferNonBlocking (I2C\_Type \*base, i2c\_master\_handle\_t \*handle, i2c\_master\_transfer\_t \*xfer)

MCUXpresso SDK API Reference Manual

Performs a master interrupt non-blocking transfer on the I2C bus.

• status\_t I2C\_MasterTransferGetCount (I2C\_Type \*base, i2c\_master\_handle\_t \*handle, size\_t \*count)

*Gets the master transfer status during a interrupt non-blocking transfer.* 

• status\_t I2C\_MasterTransferAbort (I2C\_Type \*base, i2c\_master\_handle\_t \*handle)

Aborts an interrupt non-blocking transfer early.

• void I2C\_MasterTransferHandleIRQ (I2C\_Type \*base, void \*i2cHandle)

Master interrupt handler.

• void I2C\_SlaveTransferCreateHandle (I2C\_Type \*base, i2c\_slave\_handle\_t \*handle, i2c\_slave\_transfer\_callback\_t callback, void \*userData)

*Initializes the I2C handle which is used in transactional functions.* 

• status\_t I2C\_SlaveTransferNonBlocking (I2C\_Type \*base, i2c\_slave\_handle\_t \*handle, uint32\_t eventMask)

Starts accepting slave transfers.

- void I2C\_SlaveTransferAbort (I2C\_Type \*base, i2c\_slave\_handle\_t \*handle)

  Aborts the slave transfer.
- status\_t I2C\_SlaveTransferGetCount (I2C\_Type \*base, i2c\_slave\_handle\_t \*handle, size\_t \*count) Gets the slave transfer remaining bytes during a interrupt non-blocking transfer.
- void I2C\_SlaveTransferHandleIRQ (I2C\_Type \*base, void \*i2cHandle) Slave interrupt handler.

#### 9.2.3 Data Structure Documentation

## 9.2.3.1 struct i2c master config t

## **Data Fields**

- bool enableMaster
  - *Enables the I2C peripheral at initialization time.*
- uint32 t baudRate Bps

Baud rate configuration of I2C peripheral.

#### 9.2.3.1.0.4 Field Documentation

- 9.2.3.1.0.4.1 bool i2c master config t::enableMaster
- 9.2.3.1.0.4.2 uint32\_t i2c\_master\_config\_t::baudRate\_Bps

## 9.2.3.2 struct i2c master transfer t

#### **Data Fields**

- uint32 t flags
  - A transfer flag which controls the transfer.
- uint8\_t slaveAddress
  - 7-bit slave address.
- i2c\_direction\_t direction

A transfer direction, read or write.

• uint32\_t subaddress

#### MCUXpresso SDK API Reference Manual

A sub address.

• uint8 t subaddressSize

A size of the command buffer.

• uint8\_t \*volatile data

A transfer buffer.

• volatile size t dataSize

A transfer size.

### 9.2.3.2.0.5 Field Documentation

9.2.3.2.0.5.1 uint32\_t i2c\_master\_transfer\_t::flags

9.2.3.2.0.5.2 uint8\_t i2c\_master\_transfer\_t::slaveAddress

9.2.3.2.0.5.3 i2c\_direction\_t i2c\_master\_transfer\_t::direction

9.2.3.2.0.5.4 uint32\_t i2c\_master\_transfer\_t::subaddress

Transferred MSB first.

9.2.3.2.0.5.5 uint8\_t i2c\_master\_transfer\_t::subaddressSize

9.2.3.2.0.5.6 uint8 t\* volatile i2c master transfer t::data

9.2.3.2.0.5.7 volatile size t i2c master transfer t::dataSize

9.2.3.3 struct i2c master handle

I2C master handle typedef.

#### **Data Fields**

• i2c\_master\_transfer\_t transfer

I2C master transfer copy.

• size t transferSize

Total bytes to be transferred.

• uint8\_t state

A transfer state maintained during transfer.

• i2c\_master\_transfer\_callback\_t completionCallback

A callback function called when the transfer is finished.

void \* userData

A callback parameter passed to the callback function.

#### 9.2.3.3.0.6 Field Documentation

9.2.3.3.0.6.1 i2c\_master\_transfer\_t i2c\_master\_handle\_t::transfer

9.2.3.3.0.6.2 size\_t i2c\_master\_handle\_t::transferSize

9.2.3.3.0.6.3 uint8\_t i2c\_master\_handle\_t::state

9.2.3.3.0.6.4 i2c\_master\_transfer\_callback\_t i2c\_master\_handle\_t::completionCallback

9.2.3.3.0.6.5 void\* i2c\_master\_handle\_t::userData

9.2.3.4 struct i2c slave config t

## **Data Fields**

bool enableSlave

Enables the I2C peripheral at initialization time.

• uint16 t slaveAddress

A slave address configuration.

#### 9.2.3.4.0.7 Field Documentation

9.2.3.4.0.7.1 bool i2c\_slave\_config\_t::enableSlave

9.2.3.4.0.7.2 uint16\_t i2c\_slave\_config\_t::slaveAddress

9.2.3.5 struct i2c slave transfer t

#### **Data Fields**

• i2c slave transfer event t event

A reason that the callback is invoked.

• uint8 t \*volatile data

A transfer buffer.

volatile size\_t dataSize

A transfer size.

• status\_t completionStatus

Success or error code describing how the transfer completed.

• size t transferredCount

A number of bytes actually transferred since the start or since the last repeated start.

## 9.2.3.5.0.8 Field Documentation

9.2.3.5.0.8.1 i2c\_slave\_transfer\_event\_t i2c\_slave\_transfer\_t::event

9.2.3.5.0.8.2 uint8\_t\* volatile i2c\_slave\_transfer\_t::data

9.2.3.5.0.8.3 volatile size\_t i2c\_slave\_transfer\_t::dataSize

9.2.3.5.0.8.4 status\_t i2c\_slave\_transfer\_t::completionStatus

Only applies for kI2C\_SlaveCompletionEvent.

9.2.3.5.0.8.5 size ti2c slave transfer t::transferredCount

9.2.3.6 struct \_i2c\_slave\_handle

I2C slave handle typedef.

## **Data Fields**

• volatile uint8\_t state

A transfer state maintained during transfer.

• i2c\_slave\_transfer\_t transfer

*I2C* slave transfer copy.

• uint32\_t eventMask

A mask of enabled events.

• i2c\_slave\_transfer\_callback\_t callback

A callback function called at the transfer event.

void \* userData

A callback parameter passed to the callback.

MCUXpresso SDK API Reference Manual

#### 9.2.3.6.0.9 Field Documentation

- 9.2.3.6.0.9.1 volatile uint8\_t i2c\_slave\_handle\_t::state
- 9.2.3.6.0.9.2 i2c\_slave\_transfer\_t i2c slave handle t::transfer
- 9.2.3.6.0.9.3 uint32\_t i2c\_slave\_handle\_t::eventMask
- 9.2.3.6.0.9.4 i2c\_slave\_transfer\_callback\_t i2c\_slave\_handle\_t::callback
- 9.2.3.6.0.9.5 void\* i2c slave handle t::userData

#### 9.2.4 Macro Definition Documentation

- 9.2.4.1 #define FSL\_I2C\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 4))
- 9.2.4.2 #define I2C\_WAIT\_TIMEOUT 0U /\* Define to zero means keep waiting until the flag is assert/deassert. \*/

## 9.2.5 Typedef Documentation

- 9.2.5.1 typedef void(\* i2c\_master\_transfer\_callback\_t)(I2C\_Type \*base, i2c\_master\_handle\_t \*handle, status\_t status, void \*userData)
- 9.2.5.2 typedef void(\* i2c\_slave\_transfer\_callback\_t)(I2C\_Type \*base, i2c\_slave\_transfer\_t \*xfer, void \*userData)

## 9.2.6 Enumeration Type Documentation

## **9.2.6.1** enum i2c status

#### Enumerator

kStatus\_12C\_Busy I2C is busy with current transfer.

kStatus 12C Idle Bus is Idle.

kStatus\_I2C\_Nak NAK received during transfer.

kStatus 12C ArbitrationLost Arbitration lost during transfer.

kStatus\_12C\_Timeout Timeout poling status flags.

kStatus\_12C\_Addr\_Nak NAK received during the address probe.

## 9.2.6.2 enum <u>i2c\_flags</u>

The following status register flags can be cleared:

• kI2C\_ArbitrationLostFlag

## MCUXpresso SDK API Reference Manual

## • kI2C\_IntPendingFlag

#### Note

These enumerations are meant to be OR'd together to form a bit mask.

### Enumerator

kI2C\_ReceiveNakFlag I2C receive NAK flag.

kI2C\_IntPendingFlag I2C interrupt pending flag.

kI2C\_TransferDirectionFlag I2C transfer direction flag.

kI2C\_ArbitrationLostFlag I2C arbitration lost flag.

kI2C\_BusBusyFlag I2C bus busy flag.

kI2C\_AddressMatchFlag I2C address match flag.

kI2C\_TransferCompleteFlag I2C transfer complete flag.

## 9.2.6.3 enum \_i2c\_interrupt\_enable

#### Enumerator

kI2C\_GlobalInterruptEnable I2C global interrupt.

## 9.2.6.4 enum i2c\_direction\_t

#### Enumerator

kI2C Write Master transmits to the slave.

**kI2C** Read Master receives from the slave.

## 9.2.6.5 enum \_i2c\_master\_transfer\_flags

#### Enumerator

kI2C\_TransferDefaultFlag A transfer starts with a start signal, stops with a stop signal.

**kI2C\_TransferNoStartFlag** A transfer starts without a start signal, only support write only or write+read with no start flag, do not support read only with no start flag.

kI2C\_TransferRepeatedStartFlag A transfer starts with a repeated start signal.

kI2C\_TransferNoStopFlag A transfer ends without a stop signal.

## 9.2.6.6 enum i2c\_slave\_transfer\_event\_t

These event enumerations are used for two related purposes. First, a bit mask created by OR'ing together events is passed to I2C\_SlaveTransferNonBlocking() to specify which events to enable. Then, when the slave callback is invoked, it is passed the current event through its *transfer* parameter.

## Note

These enumerations are meant to be OR'd together to form a bit mask of events.

#### Enumerator

kI2C\_SlaveAddressMatchEvent Received the slave address after a start or repeated start.

**kI2C\_SlaveTransmitEvent** A callback is requested to provide data to transmit (slave-transmitter role).

**kI2C\_SlaveReceiveEvent** A callback is requested to provide a buffer in which to place received data (slave-receiver role).

kI2C SlaveTransmitAckEvent A callback needs to either transmit an ACK or NACK.

**kI2C** SlaveCompletionEvent A stop was detected or finished transfer, completing the transfer.

*kI2C\_SlaveAllEvents* A bit mask of all available events.

## 9.2.7 Function Documentation

## 9.2.7.1 void I2C\_MasterInit ( I2C\_Type \* base, const i2c\_master\_config\_t \* masterConfig, uint32 t srcClock\_Hz )

Call this API to ungate the I2C clock and configure the I2C with master configuration.

### Note

This API should be called at the beginning of the application. Otherwise, any operation to the I2C module can cause a hard fault because the clock is not enabled. The configuration structure can be custom filled or it can be set with default values by using the I2C\_MasterGetDefaultConfig(). After calling this API, the master is ready to transfer. This is an example.

```
* i2c_master_config_t config = {
* .enableMaster = true,
* .baudRate_Bps = 100000
* };
* I2C_MasterInit(I2C0, &config, 12000000U);
*
```

#### **Parameters**

| base         | I2C base pointer                                |
|--------------|-------------------------------------------------|
| masterConfig | A pointer to the master configuration structure |
| srcClock_Hz  | I2C peripheral clock frequency in Hz            |

## 9.2.7.2 void I2C\_MasterDeinit ( I2C\_Type \* base )

Call this API to gate the I2C clock. The I2C master module can't work unless the I2C MasterInit is called.

#### **Parameters**

| base 1 | I2C base pointer |
|--------|------------------|
|--------|------------------|

## 9.2.7.3 void I2C\_MasterGetDefaultConfig ( i2c\_master\_config\_t \* masterConfig )

The purpose of this API is to get the configuration structure initialized for use in the I2C\_MasterInit(). Use the initialized structure unchanged in the I2C\_MasterInit() or modify the structure before calling the I2C\_MasterInit(). This is an example.

```
* i2c_master_config_t config;
* I2C_MasterGetDefaultConfig(&config);
*
```

#### **Parameters**

| ~ ^           |                                                  |
|---------------|--------------------------------------------------|
| masterConfig  | A pointer to the master configuration structure. |
| master conjug | 11 pointer to the muster comiguration structure. |

## 9.2.7.4 void I2C\_SlaveInit ( I2C\_Type \* base, const i2c\_slave\_config\_t \* slaveConfig\_)

Call this API to ungate the I2C clock and initialize the I2C with the slave configuration.

Note

This API should be called at the beginning of the application. Otherwise, any operation to the I2C module can cause a hard fault because the clock is not enabled. The configuration structure can partly be set with default values by I2C\_SlaveGetDefaultConfig() or it can be custom filled by the user. This is an example.

```
* i2c_slave_config_t config = {
* .enableSlave = true,
* .slaveAddress = 0x1DU,
* };
* I2C_SlaveInit(I2C0, &config);
```

## MCUXpresso SDK API Reference Manual

#### **Parameters**

| base        | I2C base pointer                               |
|-------------|------------------------------------------------|
| slaveConfig | A pointer to the slave configuration structure |
| srcClock_Hz | I2C peripheral clock frequency in Hz           |

## 9.2.7.5 void I2C\_SlaveDeinit ( I2C\_Type \* base )

Calling this API gates the I2C clock. The I2C slave module can't work unless the I2C\_SlaveInit is called to enable the clock.

#### **Parameters**

| base | I2C base pointer |
|------|------------------|
|------|------------------|

## 9.2.7.6 void I2C\_SlaveGetDefaultConfig ( i2c\_slave\_config\_t \* slaveConfig )

The purpose of this API is to get the configuration structure initialized for use in the I2C\_SlaveInit(). Modify fields of the structure before calling the I2C\_SlaveInit(). This is an example.

```
* i2c_slave_config_t config;
* I2C_SlaveGetDefaultConfig(&config);
```

#### **Parameters**

| slaveConfig | A pointer to the slave configuration structure. |
|-------------|-------------------------------------------------|
|-------------|-------------------------------------------------|

## 9.2.7.7 static void I2C\_Enable ( I2C\_Type \* base, bool enable ) [inline], [static]

## **Parameters**

| base   | I2C base pointer                                     |
|--------|------------------------------------------------------|
| enable | Pass true to enable and false to disable the module. |

## 9.2.7.8 static uint32\_t I2C\_MasterGetStatusFlags ( I2C\_Type \* base ) [inline], [static]

## MCUXpresso SDK API Reference Manual

#### **Parameters**

| base | I2C base pointer |
|------|------------------|
|------|------------------|

## Returns

status flag, use status flag to AND \_i2c\_flags to get the related status.

## 9.2.7.9 static void I2C\_MasterClearStatusFlags ( I2C\_Type \* base, uint32\_t statusMask ) [inline], [static]

The following status register flags can be cleared kI2C\_ArbitrationLostFlag and kI2C\_IntPendingFlag.

#### **Parameters**

| base       | I2C base pointer                                                                                                                                                              |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| statusMask | The status flag mask, defined in type i2c_status_flag_t. The parameter can be any combination of the following values:  • kI2C_ArbitrationLostFlag  • kI2C_IntPendingFlagFlag |

## 9.2.7.10 static uint32\_t I2C\_SlaveGetStatusFlags ( I2C\_Type \* base ) [inline], [static]

## **Parameters**

| base | I2C base pointer |
|------|------------------|

## Returns

status flag, use status flag to AND \_i2c\_flags to get the related status.

# 9.2.7.11 static void I2C\_SlaveClearStatusFlags ( I2C\_Type \* base, uint32\_t statusMask ) [inline], [static]

The following status register flags can be cleared kI2C\_ArbitrationLostFlag and kI2C\_IntPendingFlag

## Parameters

| base       | I2C base pointer                                                                                                                                  |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| statusMask | The status flag mask, defined in type i2c_status_flag_t. The parameter can be any combination of the following values:  • kI2C_IntPendingFlagFlag |

## 9.2.7.12 void I2C\_EnableInterrupts ( I2C\_Type \* base, uint32\_t mask )

## Parameters

| base | I2C base pointer                                                                                                                                                                                                                                              |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mask | <ul> <li>interrupt source The parameter can be combination of the following source if defined:</li> <li>kI2C_GlobalInterruptEnable</li> <li>kI2C_StopDetectInterruptEnable/kI2C_StartDetectInterruptEnable</li> <li>kI2C_SdaTimeoutInterruptEnable</li> </ul> |

## 9.2.7.13 void I2C\_DisableInterrupts ( I2C\_Type \* base, uint32\_t mask )

## Parameters

| base | I2C base pointer                                                                                                                                                                                                                                              |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mask | <ul> <li>interrupt source The parameter can be combination of the following source if defined:</li> <li>kI2C_GlobalInterruptEnable</li> <li>kI2C_StopDetectInterruptEnable/kI2C_StartDetectInterruptEnable</li> <li>kI2C_SdaTimeoutInterruptEnable</li> </ul> |

# 9.2.7.14 void I2C\_MasterSetBaudRate ( I2C\_Type \* base, uint32\_t baudRate\_Bps, uint32\_t srcClock\_Hz )

Parameters

| base         | I2C base pointer           |  |
|--------------|----------------------------|--|
| baudRate_Bps | the baud rate value in bps |  |
| srcClock_Hz  | Source clock               |  |

## 9.2.7.15 status\_t I2C\_MasterStart ( I2C\_Type \* base, uint8\_t address, i2c\_direction\_t direction )

This function is used to initiate a new master mode transfer by sending the START signal. The slave address is sent following the I2C START signal.

## **Parameters**

| base      | I2C peripheral base pointer                   |  |
|-----------|-----------------------------------------------|--|
| address   | 7-bit slave device address.                   |  |
| direction | Master transfer directions(transmit/receive). |  |

## Return values

| kStatus_Success  | Successfully send the start signal. |
|------------------|-------------------------------------|
| kStatus_I2C_Busy | Current bus is busy.                |

## 9.2.7.16 status\_t I2C\_MasterStop ( I2C\_Type \* base )

#### Return values

| kStatus_Success     | Successfully send the stop signal. |
|---------------------|------------------------------------|
| kStatus_I2C_Timeout | Send stop signal failed, timeout.  |

# 9.2.7.17 status\_t I2C\_MasterRepeatedStart ( I2C\_Type \* base, uint8\_t address, i2c\_direction\_t direction )

## Parameters

| base | I2C peripheral base pointer |
|------|-----------------------------|
|------|-----------------------------|

MCUXpresso SDK API Reference Manual

| address                                                 | 7-bit slave device address. |
|---------------------------------------------------------|-----------------------------|
| direction Master transfer directions(transmit/receive). |                             |

## Return values

| kStatus_Success  | Successfully send the start signal.                         |
|------------------|-------------------------------------------------------------|
| kStatus_I2C_Busy | Current bus is busy but not occupied by current I2C master. |

# 9.2.7.18 status\_t I2C\_MasterWriteBlocking ( I2C\_Type \* base, const uint8\_t \* txBuff, size\_t txSize, uint32\_t flags )

#### **Parameters**

| base                                                                                                                                                         | The I2C peripheral base pointer.                   |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|
| txBuff                                                                                                                                                       | The pointer to the data to be transferred.         |
| txSize                                                                                                                                                       | The length in bytes of the data to be transferred. |
| flags Transfer control flag to decide whether need to send a stop, use kI2C_Transfer DefaultFlag to issue a stop and kI2C_TransferNoStop to not send a stop. |                                                    |

## Return values

| kStatus_Success          | Successfully complete the data transmission. |
|--------------------------|----------------------------------------------|
| kStatus_I2C_Arbitration- | Transfer error, arbitration lost.            |
| Lost                     |                                              |
| kStataus_I2C_Nak         | Transfer error, receive NAK during transfer. |

# 9.2.7.19 status\_t I2C\_MasterReadBlocking ( I2C\_Type \* base, uint8\_t \* rxBuff, size\_t rxSize, uint32\_t flags )

## Note

The I2C\_MasterReadBlocking function stops the bus before reading the final byte. Without stopping the bus prior for the final read, the bus issues another read, resulting in garbage data being read into the data register.

MCUXpresso SDK API Reference Manual

## Parameters

| base   | I2C peripheral base pointer.                                                                                                                           |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| rxBuff | The pointer to the data to store the received data.                                                                                                    |
| rxSize | The length in bytes of the data to be received.                                                                                                        |
| flags  | Transfer control flag to decide whether need to send a stop, use kI2C_Transfer-DefaultFlag to issue a stop and kI2C_TransferNoStop to not send a stop. |

## Return values

| kStatus_Success     | Successfully complete the data transmission. |
|---------------------|----------------------------------------------|
| kStatus_I2C_Timeout | Send stop signal failed, timeout.            |

# 9.2.7.20 status\_t I2C\_SlaveWriteBlocking ( I2C\_Type \* base, const uint8\_t \* txBuff, size\_t txSize )

## Parameters

| base   | The I2C peripheral base pointer.                   |
|--------|----------------------------------------------------|
| txBuff | The pointer to the data to be transferred.         |
| txSize | The length in bytes of the data to be transferred. |

## Return values

| kStatus_Success          | Successfully complete the data transmission. |
|--------------------------|----------------------------------------------|
| kStatus_I2C_Arbitration- | Transfer error, arbitration lost.            |
| Lost                     |                                              |
| kStataus_I2C_Nak         | Transfer error, receive NAK during transfer. |

# 9.2.7.21 status\_t I2C\_SlaveReadBlocking ( I2C\_Type \* base, uint8\_t \* rxBuff, size\_t rxSize )

MCUXpresso SDK API Reference Manual

| base   | I2C peripheral base pointer.                        |
|--------|-----------------------------------------------------|
| rxBuff | The pointer to the data to store the received data. |
| rxSize | The length in bytes of the data to be received.     |

# 9.2.7.22 status\_t I2C\_MasterTransferBlocking ( I2C\_Type \* base, i2c\_master\_transfer\_t \* xfer )

## Note

The API does not return until the transfer succeeds or fails due to arbitration lost or receiving a NAK.

### Parameters

| base | I2C peripheral base address.       |
|------|------------------------------------|
| xfer | Pointer to the transfer structure. |

## Return values

| kStatus_Success          | Successfully complete the data transmission. |
|--------------------------|----------------------------------------------|
| kStatus_I2C_Busy         | Previous transmission still not finished.    |
| kStatus_I2C_Timeout      | Transfer error, wait signal timeout.         |
| kStatus_I2C_Arbitration- | Transfer error, arbitration lost.            |
| Lost                     |                                              |
| kStataus_I2C_Nak         | Transfer error, receive NAK during transfer. |

# 9.2.7.23 void I2C\_MasterTransferCreateHandle ( I2C\_Type \* base, i2c\_master\_handle\_t \* handle, i2c\_master\_transfer\_callback\_t callback, void \* userData )

#### Parameters

| base     | I2C base pointer.                                                     |
|----------|-----------------------------------------------------------------------|
| handle   | pointer to i2c_master_handle_t structure to store the transfer state. |
| callback | pointer to user callback function.                                    |

MCUXpresso SDK API Reference Manual

| userData      | user parameter passed to the callback function. |
|---------------|-------------------------------------------------|
| tibe i Delici | aser parameter passes to the cameach ranetion.  |

# 9.2.7.24 status\_t I2C\_MasterTransferNonBlocking ( I2C\_Type \* base, i2c\_master\_handle\_t \* handle, i2c\_master\_transfer\_t \* xfer )

#### Note

Calling the API returns immediately after transfer initiates. The user needs to call I2C\_MasterGet-TransferCount to poll the transfer status to check whether the transfer is finished. If the return status is not kStatus\_I2C\_Busy, the transfer is finished.

#### **Parameters**

| base   | I2C base pointer.                                                         |
|--------|---------------------------------------------------------------------------|
| handle | pointer to i2c_master_handle_t structure which stores the transfer state. |
| xfer   | pointer to i2c_master_transfer_t structure.                               |

## Return values

| kStatus_Success     | Successfully start the data transmission. |
|---------------------|-------------------------------------------|
| kStatus_I2C_Busy    | Previous transmission still not finished. |
| kStatus_I2C_Timeout | Transfer error, wait signal timeout.      |

# 9.2.7.25 status\_t l2C\_MasterTransferGetCount ( l2C\_Type \* base, i2c\_master\_handle\_t \* handle, size\_t \* count )

## Parameters

| base   | I2C base pointer.                                                         |
|--------|---------------------------------------------------------------------------|
| handle | pointer to i2c_master_handle_t structure which stores the transfer state. |
| count  | Number of bytes transferred so far by the non-blocking transaction.       |

## Return values

| kStatus_InvalidArgument | count is Invalid.              |
|-------------------------|--------------------------------|
| kStatus_Success         | Successfully return the count. |

# 9.2.7.26 status\_t I2C\_MasterTransferAbort ( I2C\_Type \* base, i2c\_master\_handle\_t \* handle )

#### Note

This API can be called at any time when an interrupt non-blocking transfer initiates to abort the transfer early.

#### **Parameters**

| base   | I2C base pointer.                                                        |
|--------|--------------------------------------------------------------------------|
| handle | pointer to i2c_master_handle_t structure which stores the transfer state |

## Return values

| kStatus_I2C_Timeout | Timeout during polling flag.     |
|---------------------|----------------------------------|
| kStatus_Success     | Successfully abort the transfer. |

## 9.2.7.27 void I2C\_MasterTransferHandleIRQ ( I2C\_Type \* base, void \* i2cHandle )

## **Parameters**

| base      | I2C base pointer.                         |
|-----------|-------------------------------------------|
| i2cHandle | pointer to i2c_master_handle_t structure. |

# 9.2.7.28 void I2C\_SlaveTransferCreateHandle ( I2C\_Type \* base, i2c\_slave\_handle\_t \* handle, i2c\_slave\_transfer\_callback\_t callback, void \* userData )

## **Parameters**

| base | I2C hase pointer  |
|------|-------------------|
| base | 12C base pointer. |

## MCUXpresso SDK API Reference Manual

127

| handle   | pointer to i2c_slave_handle_t structure to store the transfer state. |
|----------|----------------------------------------------------------------------|
| callback | pointer to user callback function.                                   |
| userData | user parameter passed to the callback function.                      |

## 9.2.7.29 status\_t I2C\_SlaveTransferNonBlocking ( I2C\_Type \* base, i2c\_slave\_handle\_t \* handle, uint32\_t eventMask )

Call this API after calling the I2C\_SlaveInit() and I2C\_SlaveTransferCreateHandle() to start processing transactions driven by an I2C master. The slave monitors the I2C bus and passes events to the callback that was passed into the call to I2C\_SlaveTransferCreateHandle(). The callback is always invoked from the interrupt context.

The set of events received by the callback is customizable. To do so, set the *eventMask* parameter to the OR'd combination of i2c\_slave\_transfer\_event\_t enumerators for the events you wish to receive. The k-I2C\_SlaveTransmitEvent and #kLPI2C\_SlaveReceiveEvent events are always enabled and do not need to be included in the mask. Alternatively, pass 0 to get a default set of only the transmit and receive events that are always enabled. In addition, the kI2C\_SlaveAllEvents constant is provided as a convenient way to enable all events.

#### **Parameters**

| base      | The I2C peripheral base address.                                                                                                                                                                                                                                   |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| handle    | Pointer to #i2c_slave_handle_t structure which stores the transfer state.                                                                                                                                                                                          |
| eventMask | Bit mask formed by OR'ing together i2c_slave_transfer_event_t enumerators to specify which events to send to the callback. Other accepted values are 0 to get a default set of only the transmit and receive events, and kI2C_SlaveAllEvents to enable all events. |

#### Return values

| #kStatus_Success | Slave transfers were successfully started.                |
|------------------|-----------------------------------------------------------|
| kStatus_I2C_Busy | Slave transfers have already been started on this handle. |

## 9.2.7.30 void I2C\_SlaveTransferAbort ( I2C\_Type \* base, i2c\_slave\_handle\_t \* handle )

Note

This API can be called at any time to stop slave for handling the bus events.

## **I2C Driver**

## Parameters

| base   | I2C base pointer.                                                        |
|--------|--------------------------------------------------------------------------|
| handle | pointer to i2c_slave_handle_t structure which stores the transfer state. |

## 9.2.7.31 status\_t I2C\_SlaveTransferGetCount ( I2C\_Type \* base, i2c\_slave\_handle\_t \* handle, size\_t \* count )

## Parameters

| base   | I2C base pointer.                                                   |  |
|--------|---------------------------------------------------------------------|--|
| handle | pointer to i2c_slave_handle_t structure.                            |  |
| count  | Number of bytes transferred so far by the non-blocking transaction. |  |

## Return values

| kStatus_InvalidArgument | count is Invalid.              |
|-------------------------|--------------------------------|
| kStatus_Success         | Successfully return the count. |

## 9.2.7.32 void I2C\_SlaveTransferHandleIRQ ( I2C\_Type \* base, void \* i2cHandle )

## Parameters

| base      | I2C base pointer.                                                       |
|-----------|-------------------------------------------------------------------------|
| i2cHandle | pointer to i2c_slave_handle_t structure which stores the transfer state |

MCUXpresso SDK API Reference Manual

NXP So

## 9.3 I2C FreeRTOS Driver

## 9.3.1 Overview

## **Driver version**

• #define FSL\_I2C\_FREERTOS\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 3)) *I2C freertos driver version 2.0.3.* 

## **I2C RTOS Operation**

- status\_t I2C\_RTOS\_Init (i2c\_rtos\_handle\_t \*handle, I2C\_Type \*base, const i2c\_master\_config\_t \*masterConfig, uint32\_t srcClock\_Hz)
   Initializes I2C.
- status\_t I2C\_RTOS\_Deinit (i2c\_rtos\_handle\_t \*handle)

  Deinitializes the I2C.
- status\_t I2C\_RTOS\_Transfer (i2c\_rtos\_handle\_t \*handle, i2c\_master\_transfer\_t \*transfer) Performs the I2C transfer.

### 9.3.2 Macro Definition Documentation

## 9.3.2.1 #define FSL I2C FREERTOS DRIVER VERSION (MAKE VERSION(2, 0, 3))

## 9.3.3 Function Documentation

## 9.3.3.1 status\_t I2C\_RTOS\_Init ( i2c\_rtos\_handle\_t \* handle, I2C\_Type \* base, const i2c\_master\_config\_t \* masterConfig, uint32 t srcClock\_Hz )

This function initializes the I2C module and the related RTOS context.

#### **Parameters**

| handle       | The RTOS I2C handle, the pointer to an allocated space for RTOS context. |  |
|--------------|--------------------------------------------------------------------------|--|
| base         | The pointer base address of the I2C instance to initialize.              |  |
| masterConfig | The configuration structure to set-up I2C in master mode.                |  |
| srcClock_Hz  | The frequency of an input clock of the I2C module.                       |  |

#### Returns

status of the operation.

## **I2C FreeRTOS Driver**

## 9.3.3.2 status\_t I2C\_RTOS\_Deinit ( i2c\_rtos\_handle\_t \* handle )

This function deinitializes the I2C module and the related RTOS context.

## **Parameters**

| handle | The RTOS I2C handle. |
|--------|----------------------|
|--------|----------------------|

# 9.3.3.3 status\_t I2C\_RTOS\_Transfer ( i2c\_rtos\_handle\_t \* handle, i2c\_master\_transfer\_t \* transfer )

This function performs the I2C transfer according to the data given in the transfer structure.

## **Parameters**

| handle   | The RTOS I2C handle.                            |
|----------|-------------------------------------------------|
| transfer | A structure specifying the transfer parameters. |

## Returns

status of the operation.

## **I2C FreeRTOS Driver**

**Chapter 10 PWM: Pulse Width Modulation Driver** 

#### Overview 10.1

## **Modules**

• PWM Driver

## 10.2 PWM Driver

#### 10.2.1 Overview

The MCUXpresso SDK provides a peripheral driver for the Pulse Width Modulation (PWM) module of MCUXpresso SDK devices.

The function PWM\_Init() initializes the PWM with a specified configurations. The function PWM\_Get-DefaultConfig() gets the default configurations. The initialization function configures the PWM for the requested register update mode for registers with buffers.

The function PWM\_Deinit() disables the PWM counter and turns off the module clock.

## 10.2.2 Typical use case

#### 10.2.2.1 **PWM** output

Output PWM signal on PWM3 module with different dutycycles. Periodically update the PWM signal duty cycle. Refer to the driver examples codes located at <SDK\_ROOT>/boards/<BOARD>/driver\_examples/pwm

#### **Enumerations**

```
enum pwm_clock_source_t {
 kPWM PeripheralClock = 1U,
 kPWM_HighFrequencyClock,
 kPWM_LowFrequencyClock }
    PWM clock source select.
enum pwm_fifo_water_mark_t {
 kPWM_FIFOWaterMark_1 = 0U,
 kPWM FIFOWaterMark 2,
 kPWM FIFOWaterMark 3,
 kPWM FIFOWaterMark 4 }
    PWM FIFO water mark select.
• enum pwm_byte_data_swap_t {
 kPWM_ByteNoSwap = 0U,
 kPWM_ByteSwap }
    PWM byte data swap select.
enum pwm_half_word_data_swap_t {
 kPWM_HalfWordNoSwap = 0U,
 kPWM HalfWordSwap }
    PWM half-word data swap select.
enum pwm_output_configuration_t {
 kPWM_SetAtRolloverAndClearAtcomparison = 0U,
 kPWM_ClearAtRolloverAndSetAtcomparison,
 kPWM NoConfigure }
```

```
PWM Output Configuration.
enum pwm_sample_repeat_t {
 kPWM_EachSampleOnce = 0u,
 kPWM_EachSampletwice,
 kPWM EachSampleFourTimes,
 kPWM EachSampleEightTimes }
    PWM FIFO sample repeat It determines the number of times each sample from the FIFO is to be used.
enum pwm_interrupt_enable_t {
 kPWM FIFOEmptyInterruptEnable = (1U \ll 0),
 kPWM RolloverInterruptEnable = (1U \ll 1),
 kPWM CompareInterruptEnable = (1U << 2)
    List of PWM interrupt options.
enum pwm_status_flags_t {
 kPWM FIFOEmptyFlag = (1U \ll 3),
 kPWM_RolloverFlag = (1U << 4),
 kPWM_CompareFlag = (1U << 5),
 kPWM FIFOWriteErrorFlag = (1U << 6) }
    List of PWM status flags.
enum pwm_fifo_available_t {
 kPWM_NoDataInFIFOFlag = 0U,
 kPWM_OneWordInFIFOFlag,
 kPWM TwoWordsInFIFOFlag,
 kPWM ThreeWordsInFIFOFlag,
 kPWM_FourWordsInFIFOFlag }
    List of PWM FIFO available.
```

### **Functions**

```
• static void PWM_SoftwareReset (PWM_Type *base)
```

Sofrware reset.

• static void PWM\_SetPeriodValue (PWM\_Type \*base, uint32\_t value) Sets the PWM period value.

• static uint32\_t PWM\_GetPeriodValue (PWM\_Type \*base)

Gets the PWM period value.

• static uint32\_t PWM\_GetCounterValue (PWM\_Type \*base)

Gets the PWM counter value.

#### **Driver version**

• #define FSL\_PWM\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 0)) Version 2.0.0.

#### Initialization and deinitialization

• status\_t PWM\_Init (PWM\_Type \*base, const pwm\_config\_t \*config)

#### MCUXpresso SDK API Reference Manual

*Ungates the PWM clock and configures the peripheral for basic operation.* 

• void PWM\_Deinit (PWM\_Type \*base)

Gate the PWM submodule clock.

void PWM\_GetDefaultConfig (pwm\_config\_t \*config)

Fill in the PWM config struct with the default settings.

## PWM start and stop.

• static void PWM\_StartTimer (PWM\_Type \*base)

Starts the PWM counter when the PWM is enabled.

• static void PWM\_StopTimer (PWM\_Type \*base)

Stops the PWM counter when the pwm is disabled.

## **Interrupt Interface**

- static void PWM\_EnableInterrupts (PWM\_Type \*base, uint32\_t mask) Enables the selected PWM interrupts.
- static void PWM\_DisableInterrupts (PWM\_Type \*base, uint32\_t mask)

  Disables the selected PWM interrupts.
- static uint32\_t PWM\_GetEnabledInterrupts (PWM\_Type \*base)

  Gets the enabled PWM interrupts.

#### **Status Interface**

- static uint32\_t PWM\_GetStatusFlags (PWM\_Type \*base)

  Gets the PWM status flags.
- static void PWM\_clearStatusFlags (PWM\_Type \*base, uint32\_t mask) Clears the PWM status flags.
- static uint32\_t PWM\_GetFIFOAvailable (PWM\_Type \*base) Gets the PWM FIFO available.

## Sample Interface

- static void PWM\_SetSampleValue (PWM\_Type \*base, uint32\_t value) Sets the PWM sample value.
- static uint32\_t PWM\_GetSampleValue (PWM\_Type \*base) Gets the PWM sample value.

137

## 10.2.3 Enumeration Type Documentation

## 10.2.3.1 enum pwm\_clock\_source\_t

#### Enumerator

kPWM\_PeripheralClock The Peripheral clock is used as the clock.kPWM\_HighFrequencyClock High-frequency reference clock is used as the clock.kPWM\_LowFrequencyClock Low-frequency reference clock(32KHz) is used as the clock.

## 10.2.3.2 enum pwm\_fifo\_water\_mark\_t

Sets the data level at which the FIFO empty flag will be set

#### Enumerator

**kPWM\_FIFOWaterMark\_1** FIFO empty flag is set when there are more than or equal to 1 empty slots.

**kPWM\_FIFOWaterMark\_2** FIFO empty flag is set when there are more than or equal to 2 empty slots.

**kPWM\_FIFOWaterMark\_3** FIFO empty flag is set when there are more than or equal to 3 empty slots.

**kPWM\_FIFOWaterMark\_4** FIFO empty flag is set when there are more than or equal to 4 empty slots.

## 10.2.3.3 enum pwm\_byte\_data\_swap\_t

It determines the byte ordering of the 16-bit data when it goes into the FIFO from the sample register.

#### Enumerator

kPWM\_ByteNoSwap byte ordering remains the samekPWM\_ByteSwap byte ordering is reversed

## 10.2.3.4 enum pwm\_half\_word\_data\_swap\_t

### Enumerator

**kPWM\_HalfWordNoSwap** Half word swapping does not take place. **kPWM\_HalfWordSwap** Half word from write data bus are swapped.

NXP Semiconductors

#### MCUXpresso SDK API Reference Manual

## 10.2.3.5 enum pwm\_output\_configuration\_t

#### Enumerator

**kPWM\_SetAtRolloverAndClearAtcomparison** Output pin is set at rollover and cleared at comparison.

**kPWM\_ClearAtRolloverAndSetAtcomparison** Output pin is cleared at rollover and set at comparison.

**kPWM\_NoConfigure** PWM output is disconnected.

## 10.2.3.6 enum pwm\_sample\_repeat\_t

#### Enumerator

**kPWM\_EachSampleOnce** Use each sample once.

**kPWM\_EachSampletwice** Use each sample twice.

*kPWM\_EachSampleFourTimes* Use each sample four times.

**kPWM\_EachSampleEightTimes** Use each sample eight times.

## 10.2.3.7 enum pwm\_interrupt\_enable\_t

### Enumerator

kPWM\_FIFOEmptyInterruptEnable This bit controls the generation of the FIFO Empty interrupt.

**kPWM\_RolloverInterruptEnable** This bit controls the generation of the Rollover interrupt. **kPWM\_CompareInterruptEnable** This bit controls the generation of the Compare interrupt.

## 10.2.3.8 enum pwm status flags t

## Enumerator

**kPWM\_FIFOEmptyFlag** This bit indicates the FIFO data level in comparison to the water level set by FWM field in the control register.

kPWM\_RolloverFlag This bit shows that a roll-over event has occurred.

**kPWM\_CompareFlag** This bit shows that a compare event has occurred.

**kPWM\_FIFOWriteErrorFlag** This bit shows that an attempt has been made to write FIFO when it is full.

## 10.2.3.9 enum pwm\_fifo\_available\_t

#### Enumerator

**kPWM\_NoDataInFIFOFlag** No data available.

#### MCUXpresso SDK API Reference Manual

139

```
    kPWM_OneWordInFIFOFlag 1 word of data in FIFO
    kPWM_TwoWordsInFIFOFlag 2 word of data in FIFO
    kPWM_ThreeWordsInFIFOFlag 3 word of data in FIFO
    kPWM_FourWordsInFIFOFlag 4 word of data in FIFO
```

## 10.2.4 Function Documentation

## 10.2.4.1 status\_t PWM\_Init ( PWM\_Type \* base, const pwm\_config\_t \* config\_)

Note

This API should be called at the beginning of the application using the PWM driver.

#### **Parameters**

| base   | PWM peripheral base address             |
|--------|-----------------------------------------|
| config | Pointer to user's PWM config structure. |

#### Returns

kStatus\_Success means success; else failed.

## 10.2.4.2 void PWM\_Deinit ( PWM\_Type \* base )

#### **Parameters**

```
base PWM peripheral base address
```

## 10.2.4.3 void PWM GetDefaultConfig ( pwm config t \* config )

The default values are:

```
* config->enableStopMode = false;
* config->enableDozeMode = false;
* config->enableWaitMode = false;
* config->enableDozeMode = false;
* config->enableDozeMode = false;
* config->clockSource = kPWM_LowFrequencyClock;
* config->prescale = 0U;
* config->outputConfig = kPWM_SetAtRolloverAndClearAtcomparison;
* config->fifoWater = kPWM_FIFOWaterMark_2;
* config->sampleRepeat = kPWM_EachSampleOnce;
* config->byteSwap = kPWM_ByteNoSwap;
* config->halfWordSwap = kPWM_HalfWordNoSwap;
```

```
MCUXpresso SDK API Reference Manual
```

#### **Parameters**

| config | Pointer to user's PWM config structure. |
|--------|-----------------------------------------|
|--------|-----------------------------------------|

## 10.2.4.4 static void PWM\_StartTimer( PWM\_Type \* base ) [inline], [static]

When the PWM is enabled, it begins a new period, the output pin is set to start a new period while the prescaler and counter are released and counting begins.

#### **Parameters**

| base PWM peripheral base address |  |
|----------------------------------|--|
|----------------------------------|--|

## 10.2.4.5 static void PWM\_StopTimer( PWM\_Type \* base ) [inline], [static]

#### **Parameters**

| base | PWM peripheral base address |
|------|-----------------------------|
|------|-----------------------------|

## 10.2.4.6 static void PWM\_SoftwareReset( PWM\_Type \* base ) [inline], [static]

PWM is reset when this bit is set to 1. It is a self clearing bit. Setting this bit resets all the registers to their reset values except for the STOPEN, DOZEN, WAITEN, and DBGEN bits in this control register.

#### **Parameters**

| base | PWM peripheral base address |
|------|-----------------------------|

## 10.2.4.7 static void PWM\_EnableInterrupts ( PWM\_Type \* base, uint32\_t mask ) [inline], [static]

## **Parameters**

| base | PWM peripheral base address                                                                        |
|------|----------------------------------------------------------------------------------------------------|
|      | The interrupts to enable. This is a logical OR of members of the enumeration pwminterrupt_enable_t |

## MCUXpresso SDK API Reference Manual

10.2.4.8 static void PWM\_DisableInterrupts ( PWM\_Type \* base, uint32\_t mask ) [inline], [static]

#### **Parameters**

| base | PWM peripheral base address                                                                          |
|------|------------------------------------------------------------------------------------------------------|
| mask | The interrupts to disable. This is a logical OR of members of the enumeration pwm_interrupt_enable_t |

## 10.2.4.9 static uint32\_t PWM\_GetEnabledInterrupts ( PWM\_Type \* base ) [inline], [static]

#### **Parameters**

| base | PWM peripheral base address |
|------|-----------------------------|
|------|-----------------------------|

#### Returns

The enabled interrupts. This is the logical OR of members of the enumeration pwm\_interrupt\_enable t

#### 

#### **Parameters**

| base | PWM peripheral base address |
|------|-----------------------------|
|------|-----------------------------|

#### Returns

The status flags. This is the logical OR of members of the enumeration pwm\_status\_flags\_t

## 10.2.4.11 static void PWM\_clearStatusFlags ( PWM\_Type \* base, uint32\_t mask ) [inline], [static]

#### **Parameters**

| base | PWM peripheral base address |
|------|-----------------------------|

## **MCUXpresso SDK API Reference Manual**

mask The status flags to clear. This is a logical OR of members of the enumeration pwm\_status\_flags\_t

## 10.2.4.12 static uint32\_t PWM\_GetFIFOAvailable ( PWM\_Type \* base ) [inline], [static]

#### **Parameters**

| base | PWM peripheral base address |
|------|-----------------------------|
|------|-----------------------------|

#### Returns

The status flags. This is the logical OR of members of the enumeration pwm\_fifo\_available\_t

## 10.2.4.13 static void PWM\_SetSampleValue ( PWM\_Type \* base, uint32\_t value ) [inline], [static]

#### **Parameters**

| base | PWM peripheral base address                                                                                                              |
|------|------------------------------------------------------------------------------------------------------------------------------------------|
| mask | The sample value. This is the input to the $4x16$ FIFO. The value in this register denotes the value of the sample being currently used. |
|      | denotes the value of the sample being earliertly used.                                                                                   |

## 10.2.4.14 static uint32\_t PWM\_GetSampleValue ( PWM\_Type \* base ) [inline], [static]

#### **Parameters**

| base | PWM peripheral base address |
|------|-----------------------------|
|------|-----------------------------|

#### Returns

The sample value. It can be read only when the PWM is enable.

## 10.2.4.15 static void PWM\_SetPeriodValue ( PWM\_Type \* base, uint32\_t value ) [inline], [static]

NXP Semiconductors 143

## **MCUXpresso SDK API Reference Manual**

#### **Parameters**

| base | PWM peripheral base address                                                     |
|------|---------------------------------------------------------------------------------|
| mask | The period value. The PWM period register (PWM_PWMPR) determines the period     |
|      | of the PWM output signal. Writing 0xFFFF to this register will achieve the same |
|      | result as writing $0xFFFE$ . PWMO (Hz) = PCLK(Hz) / (period +2)                 |

# 10.2.4.16 static uint32\_t PWM\_GetPeriodValue ( PWM\_Type \* base ) [inline], [static]

#### **Parameters**

| base | PWM peripheral base address |
|------|-----------------------------|

#### Returns

The period value. The PWM period register (PWM\_PWMPR) determines the period of the PWM output signal.

## 10.2.4.17 static uint32\_t PWM\_GetCounterValue ( PWM\_Type \* base ) [inline], [static]

#### **Parameters**

| base | PWM peripheral base address |
|------|-----------------------------|

#### Returns

The counter value. The current count value.

# **Chapter 11 UART: Universal Asynchronous Receiver/Transmitter Driver**

#### **Overview** 11.1

## **Modules**

- UART Driver
- UART FreeRTOS Driver

## 11.2 UART Driver

## 11.2.1 Overview

The MCUXpresso SDK provides a peripheral driver for the Universal Asynchronous Receiver/Transmitter (UART) module of MCUXpresso SDK devices.

The UART driver includes functional APIs and transactional APIs.

Functional APIs are used for UART initialization/configuration/operation for the purpose of optimization/customization. Using the functional API requires the knowledge of the UART peripheral and how to organize functional APIs to meet the application requirements. All functional APIs use the peripheral base address as the first parameter. UART functional operation groups provide the functional API set.

Transactional APIs can be used to enable the peripheral quickly and in the application if the code size and performance of transactional APIs can satisfy the requirements. If the code size and performance are critical requirements, see the transactional API implementation and write custom code. All transactional APIs use the uart\_handle\_t as the second parameter. Initialize the handle by calling the UART\_Transfer-CreateHandle() API.

Transactional APIs support asynchronous transfer, which means that the functions UART\_TransferSend-NonBlocking() and UART\_TransferReceiveNonBlocking() set up an interrupt for data transfer. When the transfer completes, the upper layer is notified through a callback function with the kStatus\_UART\_TxIdle and kStatus\_UART\_RxIdle.

Transactional receive APIs support the ring buffer. Prepare the memory for the ring buffer and pass in the start address and size while calling the UART\_TransferCreateHandle(). If passing NULL, the ring buffer feature is disabled. When the ring buffer is enabled, the received data is saved to the ring buffer in the background. The UART\_TransferReceiveNonBlocking() function first gets data from the ring buffer. If the ring buffer does not have enough data, the function first returns the data in the ring buffer and then saves the received data to user memory. When all data is received, the upper layer is informed through a callback with the kStatus\_UART\_RxIdle.

If the receive ring buffer is full, the upper layer is informed through a callback with the kStatus\_UART\_RxRingBufferOverrun. In the callback function, the upper layer reads data out from the ring buffer. If not, existing data is overwritten by the new data.

The ring buffer size is specified when creating the handle. Note that one byte is reserved for the ring buffer maintenance. When creating handle using the following code.

Refer to the driver examples codes located at <SDK\_ROOT>/boards/<BOARD>/driver\_examples/uart In this example, the buffer size is 32, but only 31 bytes are used for saving data.

## 11.2.2 Typical use case

## 11.2.2.1 UART Send/receive using a polling method

Refer to the driver examples codes located at <SDK\_ROOT>/boards/<BOARD>/driver\_examples/uart

147

## 11.2.2.2 UART Send/receive using an interrupt method

Refer to the driver examples codes located at <SDK\_ROOT>/boards/<BOARD>/driver\_examples/uart

## 11.2.2.3 UART Receive using the ringbuffer feature

Refer to the driver examples codes located at <SDK\_ROOT>/boards/<BOARD>/driver\_examples/uart

## 11.2.2.4 UART automatic baud rate detect feature

Refer to the driver examples codes located at <SDK\_ROOT>/boards/<BOARD>/driver\_examples/uart

## **Data Structures**

- struct uart\_config\_t
  - UART configuration structure. More...
- struct uart\_transfer\_t
  - UART transfer structure. More...
- struct uart\_handle\_t

UART handle structure. More...

## **Typedefs**

• typedef void(\* uart\_transfer\_callback\_t )(UART\_Type \*base, uart\_handle\_t \*handle, status\_t status, void \*userData)

UART transfer callback function.

#### **Enumerations**

```
enum _uart_status {
  kStatus_UART_TxBusy = MAKE_STATUS(kStatusGroup_IUART, 0),
 kStatus UART RxBusy = MAKE STATUS(kStatusGroup IUART, 1),
 kStatus_UART_TxIdle = MAKE_STATUS(kStatusGroup_IUART, 2),
 kStatus_UART_RxIdle = MAKE_STATUS(kStatusGroup_IUART, 3),
 kStatus UART TxWatermarkTooLarge = MAKE STATUS(kStatusGroup IUART, 4),
 kStatus UART RxWatermarkTooLarge = MAKE STATUS(kStatusGroup IUART, 5),
 kStatus_UART_FlagCannotClearManually,
 kStatus_UART_Error = MAKE_STATUS(kStatusGroup_IUART, 7),
 kStatus_UART_RxRingBufferOverrun = MAKE_STATUS(kStatusGroup_IUART, 8),
 kStatus UART RxHardwareOverrun = MAKE STATUS(kStatusGroup IUART, 9),
 kStatus_UART_NoiseError = MAKE_STATUS(kStatusGroup_IUART, 10),
 kStatus UART FramingError = MAKE STATUS(kStatusGroup IUART, 11),
 kStatus UART ParityError = MAKE STATUS(kStatusGroup IUART, 12),
 kStatus_UART_BaudrateNotSupport,
 kStatus_UART_BreakDetect = MAKE_STATUS(kStatusGroup_IUART, 14) }
    Error codes for the UART driver.
enum uart_data_bits_t {
  kUART SevenDataBits = 0x0U,
 kUART EightDataBits = 0x1U }
    UART data bits count.
enum uart_parity_mode_t {
  kUART ParityDisabled = 0x0U,
 kUART_ParityEven = 0x2U,
 kUART_ParityOdd = 0x3U }
    UART parity mode.
enum uart_stop_bit_count_t {
 kUART_OneStopBit = 0x0U,
 kUART_TwoStopBit = 0x1U }
    UART stop bit count.
• enum uart idle condition t {
  kUART IdleFor4Frames = 0x0U,
 kUART IdleFor8Frames = 0x1U,
 kUART_IdleFor16Frames = 0x2U,
 kUART IdleFor32Frames = 0x3U }
    UART idle condition detect.
• enum uart interrupt enable
    This structure contains the settings for all of the UART interrupt configurations.
enum _uart_flags {
```

MCUXpresso SDK API Reference Manual

```
kUART_RxCharReadyFlag = 0x00000000FU.
kUART_RxErrorFlag = 0x0000000EU,
kUART RxOverrunErrorFlag = 0x0000000DU,
kUART_RxFrameErrorFlag = 0x0000000CU,
kUART RxBreakDetectFlag = 0x0000000BU,
kUART_RxParityErrorFlag = 0x0000000AU,
kUART_ParityErrorFlag = 0x0094000FU,
kUART_RtsStatusFlag = 0x0094000EU,
kUART TxReadyFlag = 0x0094000DU,
kUART_RtsDeltaFlag = 0x0094000CU,
kUART_EscapeFlag = 0x0094000BU,
kUART FrameErrorFlag = 0x0094000AU,
kUART_RxReadyFlag = 0x00940009U,
kUART\_AgingTimerFlag = 0x00940008U,
kUART_DtrDeltaFlag = 0x00940007U,
kUART RxDsFlag = 0x00940006U,
kUART tAirWakeFlag = 0x00940005U,
kUART_AwakeFlag = 0x00940004U,
kUART_Rs485SlaveAddrMatchFlag = 0x00940003U,
kUART AutoBaudFlag = 0x0098000FU,
kUART_TxEmptyFlag = 0x0098000EU,
kUART DtrFlag = 0x0098000DU,
kUART_IdleFlag = 0x0098000CU,
kUART AutoBaudCntStopFlag = 0x0098000BU,
kUART_RiDeltaFlag = 0x0098000AU,
kUART_RiFlag = 0x00980009U,
kUART_IrFlag = 0x00980008U,
kUART WakeFlag = 0x00980007U,
kUART_DcdDeltaFlag = 0x00980006U,
kUART_DcdFlag = 0x00980005U,
kUART_RtsFlag = 0x00980004U,
kUART_TxCompleteFlag = 0x00980003U,
kUART BreakDetectFlag = 0x00980002U,
kUART_RxOverrunFlag = 0x00980001U,
kUART RxDataReadyFlag = 0x00980000U }
  UART status flags.
```

#### **Functions**

• uint32\_t UART\_GetInstance (UART\_Type \*base)

Get the UART instance from peripheral base address.

## MCUXpresso SDK API Reference Manual

#### **Variables**

uint32\_t uart\_config\_t::baudRate\_Bps

*UART* baud rate.

• uart\_parity\_mode\_t uart\_config\_t::parityMode

Parity error check mode of this module.

• uart data bits t uart config t::dataBitsCount

Data bits count, eight (default), seven.

uart\_stop\_bit\_count\_t uart\_config\_t::stopBitCount

*Number of stop bits in one frame.* 

• uint8\_t uart\_config\_t::txFifoWatermark

TX FIFO watermark.

uint8\_t uart\_config\_t::rxFifoWatermark

RX FIFO watermark.

bool uart\_config\_t::enableAutoBaudRate

Enable automatic baud rate detection.

• bool uart\_config\_t::enableTx

Enable TX.

bool uart\_config\_t::enableRx

Enable RX.

• uint8\_t \* uart\_transfer\_t::data

The buffer of data to be transfer.

size\_t uart\_transfer\_t::dataSize

The byte count to be transfer.

• uint8\_t \*volatile uart\_handle\_t::txData

Address of remaining data to send.

• volatile size\_t uart\_handle\_t::txDataSize

Size of the remaining data to send.

size\_t uart\_handle\_t::txDataSizeAll

Size of the data to send out.

• uint8\_t \*volatile uart\_handle\_t::rxData

Address of remaining data to receive.

volatile size\_t uart\_handle\_t::rxDataSize

Size of the remaining data to receive.

size\_t uart\_handle\_t::rxDataSizeAll

Size of the data to receive.

• uint8\_t \* uart\_handle\_t::rxRingBuffer

Start address of the receiver ring buffer.

• size\_t uart\_handle\_t::rxRingBufferSize

Size of the ring buffer.

volatile uint16\_t uart\_handle\_t::rxRingBufferHead

*Index for the driver to store received data into ring buffer.* 

• volatile uint16\_t uart\_handle\_t::rxRingBufferTail

*Index for the user to get data from the ring buffer.* 

• uart transfer callback t uart handle t::callback

Callback function.

void \* uart handle t::userData

UART callback function parameter.

volatile uint8\_t uart\_handle\_t::txState

TX transfer state.

volatile uint8\_t uart\_handle\_t::rxState

RX transfer state.

#### **Driver version**

• #define FSL\_UART\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 0)) UART driver version 2.0.0.

## **Software Reset**

• static void UART\_SoftwareReset (UART\_Type \*base)

Resets the UART using software.

## Initialization and deinitialization

- status\_t UART\_Init (UART\_Type \*base, const uart\_config\_t \*config, uint32\_t srcClock\_Hz)

  Initializes an UART instance with the user configuration structure and the peripheral clock.
- void UART\_Deinit (UART\_Type \*base)

Deinitializes a UART instance.

- void UART\_GetDefaultConfig (uart\_config\_t \*config)
- status\_t <u>UART\_SetBaudRate</u> (<u>UART\_Type</u> \*base, uint32\_t baudRate\_Bps, uint32\_t srcClock\_Hz) Sets the UART instance baud rate.
- static void UART\_Enable (UART\_Type \*base)

This function is used to Enable the UART Module.

- static void UART\_SetIdleCondition (UART\_Type \*base, uart\_idle\_condition\_t condition)

  This function is used to configure the IDLE line condition.
- static void UART\_Disable (UART\_Type \*base)

This function is used to Disable the UART Module.

#### **Status**

- bool UART\_GetStatusFlag (UART\_Type \*base, uint32\_t flag)
  - This function is used to get the current status of specific UART status flag(including interrupt flag).
- void UART\_ClearStatusFlag (UART\_Type \*base, uint32\_t flag)

This function is used to clear the current status of specific UART status flag.

## Interrupts

• void UART\_EnableInterrupts (UART\_Type \*base, uint32\_t mask)

Enables UART interrupts according to the provided mask.

• void UART\_DisableInterrupts (UART\_Type \*base, uint32\_t mask)

Disables the UART interrupts according to the provided mask.

• uint32\_t UART\_GetEnabledInterrupts (UART\_Type \*base)

Gets enabled UART interrupts.

#### MCUXpresso SDK API Reference Manual

## **Bus Operations**

• static void UART\_EnableTx (UART\_Type \*base, bool enable)

Enables or disables the UART transmitter.

• static void UART\_EnableRx (UART\_Type \*base, bool enable)

Enables or disables the UART receiver.

• static void UART\_WriteByte (UART\_Type \*base, uint8\_t data)

Writes to the transmitter register.

• static uint8\_t UART\_ReadByte (UART\_Type \*base)

Reads the receiver register.

• void UART\_WriteBlocking (UART\_Type \*base, const uint8\_t \*data, size\_t length)

Writes to the TX register using a blocking method.

• status\_t UART\_ReadBlocking (UART\_Type \*base, uint8\_t \*data, size\_t length)

Read RX data register using a blocking method.

#### **Transactional**

• void UART\_TransferCreateHandle (UART\_Type \*base, uart\_handle\_t \*handle, uart\_transfer\_callback\_t callback, void \*userData)

Initializes the UART handle.

• void UART\_TransferStartRingBuffer (UART\_Type \*base, uart\_handle\_t \*handle, uint8\_t \*ring-Buffer, size\_t ringBufferSize)

Sets up the RX ring buffer.

• void UART\_TransferStopRingBuffer (UART\_Type \*base, uart\_handle\_t \*handle)

Aborts the background transfer and uninstalls the ring buffer.

• size\_t UART\_TransferGetRxRingBufferLength (uart\_handle\_t \*handle)

Get the length of received data in RX ring buffer.

• status\_t\_UART\_TransferSendNonBlocking (UART\_Type \*base, uart\_handle\_t \*handle, uart\_transfer\_t \*xfer)

*Transmits a buffer of data using the interrupt method.* 

• void UART\_TransferAbortSend (UART\_Type \*base, uart\_handle\_t \*handle)

Aborts the interrupt-driven data transmit.

• status\_t UART\_TransferGetSendCount (UART\_Type \*base, uart\_handle\_t \*handle, uint32\_t \*count)

Gets the number of bytes written to the UART TX register.

• status\_t UART\_TransferReceiveNonBlocking (UART\_Type \*base, uart\_handle\_t \*handle, uart\_transfer\_t \*xfer, size\_t \*receivedBytes)

Receives a buffer of data using an interrupt method.

• void UART\_TransferAbortReceive (UART\_Type \*base, uart\_handle\_t \*handle)

Aborts the interrupt-driven data receiving.

• status\_t UART\_TransferGetReceiveCount (UART\_Type \*base, uart\_handle\_t \*handle, uint32\_-t \*count)

Gets the number of bytes that have been received.

• void UART\_TransferHandleIRQ (UART\_Type \*base, uart\_handle\_t \*handle) *UART IRQ handle function*.

## DMA control functions.

- static void UART\_EnableTxDMA (UART\_Type \*base, bool enable)

  Enables or disables the UART transmitter DMA request.
- static void UART\_EnableRxDMA (UART\_Type \*base, bool enable) Enables or disables the UART receiver DMA request.

#### FIFO control functions.

- static void UART\_SetTxFifoWatermark (UART\_Type \*base, uint8\_t watermark)

  This function is used to set the watermark of UART Tx FIFO.
- static void UART\_SetRxFifoWatermark (UART\_Type \*base, uint8\_t watermark)

  This function is used to set the watermark of UART Rx FIFO.

### Auto baud rate detection.

- static void UART\_EnableAutoBaudRate (UART\_Type \*base, bool enable)

  This function is used to set the enable condition of Automatic Baud Rate Detection feature.
- static bool UART\_IsAutoBaudRateComplete (UART\_Type \*base)

  This function is used to read if the automatic baud rate detection has finished.

#### 11.2.3 Data Structure Documentation

## 11.2.3.1 struct uart\_config\_t

#### **Data Fields**

- uint32\_t baudRate\_Bps
  - *UART* baud rate.
- uart\_parity\_mode\_t parityMode

Parity error check mode of this module.

- uart\_data\_bits\_t dataBitsCount
  - Data bits count, eight (default), seven.
- uart\_stop\_bit\_count\_t stopBitCount

Number of stop bits in one frame.

- uint8 t txFifoWatermark
  - TX FIFO watermark.
- uint8 t rxFifoWatermark

RX FIFO watermark.

- bool enableAutoBaudRate
  - Enable automatic baud rate detection.
- bool enableTx
  - Enable TX.
- bool enableRx

Enable RX.

NXP Semiconductors 153

## MCUXpresso SDK API Reference Manual

## 11.2.3.2 struct uart\_transfer\_t

#### **Data Fields**

• uint8 t \* data

The buffer of data to be transfer.

• size\_t dataSize

The byte count to be transfer.

#### 11.2.3.3 struct uart handle

#### **Data Fields**

• uint8 t \*volatile txData

Address of remaining data to send.

• volatile size\_t txDataSize

Size of the remaining data to send.

size\_t txDataSizeAll

Size of the data to send out.

• uint8\_t \*volatile rxData

Address of remaining data to receive.

• volatile size\_t rxDataSize

Size of the remaining data to receive.

• size\_t rxDataSizeAll

Size of the data to receive.

• uint8\_t \* rxRingBuffer

Start address of the receiver ring buffer.

• size\_t rxRingBufferSize

Size of the ring buffer.

• volatile uint16\_t rxRingBufferHead

Index for the driver to store received data into ring buffer.

• volatile uint16\_t rxRingBufferTail

*Index for the user to get data from the ring buffer.* 

• uart transfer callback t callback

Callback function.

• void \* userData

UART callback function parameter.

• volatile uint8\_t txState

TX transfer state.

• volatile uint8\_t rxState

RX transfer state.

## 11.2.4 Macro Definition Documentation

## 11.2.4.1 #define FSL\_UART\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 0))

## 11.2.5 Typedef Documentation

11.2.5.1 typedef void(\* uart\_transfer\_callback\_t)(UART\_Type \*base, uart\_handle\_t \*handle, status t status, void \*userData)

## 11.2.6 Enumeration Type Documentation

## 11.2.6.1 enum \_uart\_status

#### Enumerator

kStatus\_UART\_TxBusy Transmitter is busy.

kStatus\_UART\_RxBusy Receiver is busy.

kStatus\_UART\_TxIdle UART transmitter is idle.

kStatus\_UART\_RxIdle UART receiver is idle.

kStatus\_UART\_TxWatermarkTooLarge TX FIFO watermark too large.

kStatus\_UART\_RxWatermarkTooLarge RX FIFO watermark too large.

kStatus\_UART\_FlagCannotClearManually UART flag can't be manually cleared.

**kStatus\_UART\_Error** Error happens on UART.

kStatus UART RxRingBufferOverrun UART RX software ring buffer overrun.

kStatus\_UART\_RxHardwareOverrun UART RX receiver overrun.

kStatus UART NoiseError UART noise error.

**kStatus\_UART\_FramingError** UART framing error.

kStatus\_UART\_ParityError UART parity error.

**kStatus\_UART\_BaudrateNotSupport** Baudrate is not support in current clock source.

kStatus\_UART\_BreakDetect Receiver detect BREAK signal.

## 11.2.6.2 enum uart\_data\_bits\_t

#### Enumerator

kUART SevenDataBits Seven data bit.

kUART\_EightDataBits Eight data bit.

## 11.2.6.3 enum uart\_parity\_mode\_t

#### Enumerator

kUART\_ParityDisabled Parity disabled.

## MCUXpresso SDK API Reference Manual

kUART\_ParityEven Even error check is selected.kUART\_ParityOdd Odd error check is selected.

## 11.2.6.4 enum uart\_stop\_bit\_count\_t

#### Enumerator

kUART\_OneStopBit One stop bit.kUART\_TwoStopBit Two stop bits.

## 11.2.6.5 enum uart idle condition t

#### Enumerator

kUART\_IdleFor4Frames Idle for more than 4 frames.
 kUART\_IdleFor8Frames Idle for more than 8 frames.
 kUART\_IdleFor16Frames Idle for more than 16 frames.
 kUART IdleFor32Frames Idle for more than 32 frames.

## 11.2.6.6 enum \_uart\_interrupt\_enable

## 11.2.6.7 enum \_uart\_flags

This provides constants for the UART status flags for use in the UART functions.

#### Enumerator

kUART\_RxCharReadyFlag Rx Character Ready Flag.
kUART\_RxErrorFlag Rx Error Detect Flag.
kUART\_RxOverrunErrorFlag Rx Overrun Flag.
kUART\_RxFrameErrorFlag Rx Frame Error Flag.
kUART\_RxBreakDetectFlag Rx Break Detect Flag.
kUART\_RxParityErrorFlag Rx Parity Error Flag.
kUART\_ParityErrorFlag Parity Error Interrupt Flag.
kUART\_RtsStatusFlag RTS\_B Pin Status Flag.
kUART\_TxReadyFlag Transmitter Ready Interrupt/DMA Flag.
kUART\_RtsDeltaFlag RTS Delta Flag.
kUART\_EscapeFlag Escape Sequence Interrupt Flag.
kUART\_FrameErrorFlag Frame Error Interrupt Flag.
kUART\_RxReadyFlag Receiver Ready Interrupt/DMA Flag.
kUART\_RxReadyFlag Receiver Ready Interrupt Flag.
kUART\_AgingTimerFlag Aging Timer Interrupt Flag.
kUART\_DtrDeltaFlag DTR Delta Flag.

kUART RxDsFlag Receiver IDLE Interrupt Flag.

#### MCUXpresso SDK API Reference Manual

kUART\_tAirWakeFlag Asynchronous IR WAKE Interrupt Flag.

kUART\_AwakeFlag Asynchronous WAKE Interrupt Flag.

kUART\_Rs485SlaveAddrMatchFlag RS-485 Slave Address Detected Interrupt Flag.

kUART\_AutoBaudFlag Automatic Baud Rate Detect Complete Flag.

kUART\_TxEmptyFlag Transmit Buffer FIFO Empty.

kUART\_DtrFlag DTR edge triggered interrupt flag.

kUART\_IdleFlag Idle Condition Flag.

kUART\_AutoBaudCntStopFlag Auto-baud Counter Stopped Flag.

kUART RiDeltaFlag Ring Indicator Delta Flag.

kUART\_RiFlag Ring Indicator Input Flag.

kUART\_IrFlag Serial Infrared Interrupt Flag.

kUART WakeFlag Wake Flag.

kUART\_DcdDeltaFlag Data Carrier Detect Delta Flag.

kUART\_DcdFlag Data Carrier Detect Input Flag.

kUART\_RtsFlag RTS Edge Triggered Interrupt Flag.

kUART\_TxCompleteFlag Transmitter Complete Flag.

kUART\_BreakDetectFlag BREAK Condition Detected Flag.

**kUART\_RxOverrunFlag** Overrun Error Flag.

kUART\_RxDataReadyFlag Receive Data Ready Flag.

## 11.2.7 Function Documentation

## 11.2.7.1 uint32\_t UART\_GetInstance ( UART\_Type \* base )

**Parameters** 

base UART peripheral base address.

Returns

**UART** instance.

## 11.2.7.2 static void UART\_SoftwareReset ( UART\_Type \* base ) [inline], [static]

This function resets the transmit and receive state machines, all FIFOs and register USR1, USR2, UBIR, UBMR, UBRC, URXD, UTXD and UTS[6-3]

Parameters

**MCUXpresso SDK API Reference Manual** 

| base | UART peripheral base address. |
|------|-------------------------------|
|------|-------------------------------|

## 11.2.7.3 status\_t UART\_Init ( UART\_Type \* base, const uart\_config\_t \* config, uint32\_t srcClock\_Hz )

This function configures the UART module with user-defined settings. Call the UART\_GetDefault-Config() function to configure the configuration structure and get the default configuration. The example below shows how to use this API to configure the UART.

```
* uart_config_t uartConfig;
* uartConfig.baudRate_Bps = 115200U;
* uartConfig.parityMode = kUART_ParityDisabled;
* uartConfig.dataBitsCount = kUART_EightDataBits;
* uartConfig.stopBitCount = kUART_OneStopBit;
* uartConfig.txFifoWatermark = 2;
* uartConfig.rxFifoWatermark = 1;
* uartConfig.enableAutoBaudrate = false;
* uartConfig.enableTx = true;
* uartConfig.enableRx = true;
* UART_Init(UART1, &uartConfig, 24000000U);
**
```

#### **Parameters**

| base        | UART peripheral base address.                      |
|-------------|----------------------------------------------------|
| config      | Pointer to a user-defined configuration structure. |
| srcClock_Hz | UART clock source frequency in HZ.                 |

#### Return values

| kStatus_Success | UART initialize succeed |
|-----------------|-------------------------|
|-----------------|-------------------------|

## 11.2.7.4 void UART\_Deinit ( UART\_Type \* base )

This function waits for transmit to complete, disables TX and RX, and disables the UART clock.

## Parameters

| base | UART peripheral base address. |
|------|-------------------------------|
|------|-------------------------------|

## 11.2.7.5 void UART\_GetDefaultConfig ( uart\_config\_t \* config )

Gets the default configuration structure.

#### MCUXpresso SDK API Reference Manual

This function initializes the UART configuration structure to a default value. The default values are: uartConfig->baudRate\_Bps = 115200U; uartConfig->parityMode = kUART\_ParityDisabled; uartConfig->dataBitsCount = kUART\_EightDataBits; uartConfig->stopBitCount = kUART\_OneStopBit; uartConfig->txFifoWatermark = 2; uartConfig->rxFifoWatermark = 1; uartConfig->enableAutoBaudrate = flase; uartConfig->enableTx = false; uartConfig->enableRx = false;

#### **Parameters**

| config | Pointer to a configuration structure. |
|--------|---------------------------------------|

## 11.2.7.6 status\_t UART\_SetBaudRate ( UART\_Type \* base, uint32\_t baudRate\_Bps, uint32\_t srcClock\_Hz )

This function configures the UART module baud rate. This function is used to update the UART module baud rate after the UART module is initialized by the UART\_Init.

```
* UART_SetBaudRate(UART1, 115200U, 20000000U);
```

#### **Parameters**

| base         | UART peripheral base address.      |
|--------------|------------------------------------|
| baudRate_Bps | UART baudrate to be set.           |
| srcClock_Hz  | UART clock source frequency in Hz. |

#### Return values

| kStatus_UART_Baudrate- | Baudrate is not support in the current clock source. |
|------------------------|------------------------------------------------------|
| NotSupport             |                                                      |
| kStatus_Success        | Set baudrate succeeded.                              |

## 11.2.7.7 static void UART\_Enable ( UART\_Type \* base ) [inline], [static]

## Parameters

| base | UART base pointer. |
|------|--------------------|

## 11.2.7.8 static void UART\_SetIdleCondition ( UART\_Type \* base, uart\_idle\_condition\_t condition ) [inline], [static]

## MCUXpresso SDK API Reference Manual

#### **Parameters**

| base      | UART base pointer.                                                     |
|-----------|------------------------------------------------------------------------|
| condition | IDLE line detect condition of the enumerators in _uart_idle_condition. |

## 11.2.7.9 static void UART\_Disable ( UART\_Type \* base ) [inline], [static]

#### **Parameters**

| base | UART base pointer. |
|------|--------------------|

## 11.2.7.10 bool UART\_GetStatusFlag ( UART\_Type \* base, uint32\_t flag )

The available status flag can be select from uart\_status\_flag\_t enumeration.

#### **Parameters**

| base | UART base pointer.    |
|------|-----------------------|
| flag | Status flag to check. |

#### Return values

| current | state of corresponding status flag. |
|---------|-------------------------------------|

## 11.2.7.11 void UART\_ClearStatusFlag ( UART\_Type \* base, uint32\_t flag )

The available status flag can be select from uart\_status\_flag\_t enumeration.

#### **Parameters**

| base | UART base pointer.    |
|------|-----------------------|
| flag | Status flag to clear. |

## 11.2.7.12 void UART\_EnableInterrupts ( UART\_Type \* base, uint32\_t mask )

This function enables the UART interrupts according to the provided mask. The mask is a logical OR of enumeration members. See <u>\_uart\_interrupt\_enable</u>. For example, to enable TX empty interrupt and RX data ready interrupt, do the following.

\* UART\_EnableInterrupts(UART1, kUART\_TxEmptyEnable | kUART\_RxDataReadyEnable);

\*

## MCUXpresso SDK API Reference Manual

#### **Parameters**

| base | UART peripheral base address.                                   |
|------|-----------------------------------------------------------------|
| mask | The interrupts to enable. Logical OR of _uart_interrupt_enable. |

## 11.2.7.13 void UART\_DisableInterrupts ( UART\_Type \* base, uint32\_t mask )

This function disables the UART interrupts according to the provided mask. The mask is a logical OR of enumeration members. See <u>\_uart\_interrupt\_enable</u>. For example, to disable TX empty interrupt and RX data ready interrupt do the following.

```
* UART_EnableInterrupts(UART1,kUART_TxEmptyEnable | kUART_RxDataReadyEnable);
*
```

#### **Parameters**

| base | UART peripheral base address.                                    |
|------|------------------------------------------------------------------|
| mask | The interrupts to disable. Logical OR of _uart_interrupt_enable. |

## 11.2.7.14 uint32\_t UART\_GetEnabledInterrupts ( UART\_Type \* base )

This function gets the enabled UART interrupts. The enabled interrupts are returned as the logical OR value of the enumerators <u>\_uart\_interrupt\_enable</u>. To check a specific interrupt enable status, compare the return value with enumerators in <u>\_uart\_interrupt\_enable</u>. For example, to check whether the TX empty interrupt is enabled:

#### **Parameters**

| base | UART peripheral base address. |
|------|-------------------------------|
|------|-------------------------------|

#### Returns

UART interrupt flags which are logical OR of the enumerators in <u>uart\_interrupt\_enable</u>.

MCUXpresso SDK API Reference Manual

## 11.2.7.15 static void UART\_EnableTx ( UART\_Type \* base, bool enable ) [inline], [static]

This function enables or disables the UART transmitter.

#### **Parameters**

| base   | UART peripheral base address.     |
|--------|-----------------------------------|
| enable | True to enable, false to disable. |

## 11.2.7.16 static void UART\_EnableRx ( UART\_Type \* base, bool enable ) [inline], [static]

This function enables or disables the UART receiver.

#### **Parameters**

| base   | UART peripheral base address.     |
|--------|-----------------------------------|
| enable | True to enable, false to disable. |

## 11.2.7.17 static void UART\_WriteByte ( UART\_Type \* base, uint8\_t data ) [inline], [static]

This function is used to write data to transmitter register. The upper layer must ensure that the TX register is empty or that the TX FIFO has room before calling this function.

## Parameters

| base | UART peripheral base address.  |
|------|--------------------------------|
| data | Data write to the TX register. |

## 11.2.7.18 static uint8\_t UART\_ReadByte ( UART\_Type \* base ) [inline], [static]

This function is used to read data from receiver register. The upper layer must ensure that the receiver register is full or that the RX FIFO has data before calling this function.

## **Parameters**

| base | UART peripheral base address. |
|------|-------------------------------|

## Returns

Data read from data register.

NXP Semiconductors 163

## **UART Driver**

#### void UART\_WriteBlocking ( UART\_Type \* base, const uint8\_t \* data, size\_t 11.2.7.19 length )

This function polls the TX register, waits for the TX register to be empty or for the TX FIFO to have room and writes data to the TX buffer.

### Note

This function does not check whether all data is sent out to the bus. Before disabling the TX, check kUART\_TransmissionCompleteFlag to ensure that the TX is finished.

## **Parameters**

| base   | UART peripheral base address.       |
|--------|-------------------------------------|
| data   | Start address of the data to write. |
| length | Size of the data to write.          |

#### 11.2.7.20 status\_t UART\_ReadBlocking ( UART\_Type \* base, uint8\_t \* data, size\_t length )

This function polls the RX register, waits for the RX register to be full or for RX FIFO to have data, and reads data from the TX register.

### **Parameters**

| base   | UART peripheral base address.                           |
|--------|---------------------------------------------------------|
| data   | Start address of the buffer to store the received data. |
| length | Size of the buffer.                                     |

## Return values

| kStatus_UART_Rx-             | Receiver overrun occurred while receiving data. |
|------------------------------|-------------------------------------------------|
| HardwareOverrun              |                                                 |
| kStatus_UART_Noise-<br>Error | A noise error occurred while receiving data.    |
| Error                        |                                                 |

**NXP Semiconductors** 

165

| kStatus_UART_Framing-         | A framing error occurred while receiving data. |
|-------------------------------|------------------------------------------------|
| Error                         |                                                |
| kStatus_UART_Parity-<br>Error | A parity error occurred while receiving data.  |
| kStatus_Success               | Successfully received all data.                |

## 11.2.7.21 void UART\_TransferCreateHandle ( UART\_Type \* base, uart\_handle\_t \* handle, uart\_transfer\_callback\_t callback, void \* userData )

This function initializes the UART handle which can be used for other UART transactional APIs. Usually, for a specified UART instance, call this API once to get the initialized handle.

#### **Parameters**

| base     | UART peripheral base address.           |
|----------|-----------------------------------------|
| handle   | UART handle pointer.                    |
| callback | The callback function.                  |
| userData | The parameter of the callback function. |

## 11.2.7.22 void UART\_TransferStartRingBuffer ( UART\_Type \* base, uart\_handle\_t \* handle, uint8 t \* ringBuffer, size t ringBufferSize )

This function sets up the RX ring buffer to a specific UART handle.

When the RX ring buffer is used, data received are stored into the ring buffer even when the user doesn't call the UART\_TransferReceiveNonBlocking() API. If data is already received in the ring buffer, the user can get the received data from the ring buffer directly.

## Note

When using the RX ring buffer, one byte is reserved for internal use. In other words, if ring-BufferSize is 32, only 31 bytes are used for saving data.

## **Parameters**

| base           | UART peripheral base address.                                                                    |
|----------------|--------------------------------------------------------------------------------------------------|
| handle         | UART handle pointer.                                                                             |
| ringBuffer     | Start address of the ring buffer for background receiving. Pass NULL to disable the ring buffer. |
| ringBufferSize | Size of the ring buffer.                                                                         |

## **UART Driver**

# 11.2.7.23 void UART\_TransferStopRingBuffer ( UART\_Type \* base, uart\_handle\_t \* handle )

This function aborts the background transfer and uninstalls the ring buffer.

#### **Parameters**

| base   | UART peripheral base address. |
|--------|-------------------------------|
| handle | UART handle pointer.          |

## 11.2.7.24 size\_t UART\_TransferGetRxRingBufferLength ( uart\_handle\_t \* handle )

## **Parameters**

| handle | UART handle pointer. |
|--------|----------------------|
|--------|----------------------|

## Returns

Length of received data in RX ring buffer.

## 11.2.7.25 status\_t UART\_TransferSendNonBlocking ( UART\_Type \* base, uart\_handle\_t \* handle, uart\_transfer\_t \* xfer )

This function sends data using an interrupt method. This is a non-blocking function, which returns directly without waiting for all data to be written to the TX register. When all data is written to the TX register in the ISR, the UART driver calls the callback function and passes the kStatus\_UART\_TxIdle as status parameter.

## Note

The kStatus\_UART\_TxIdle is passed to the upper layer when all data is written to the TX register. However, it does not ensure that all data is sent out. Before disabling the TX, check the kUART\_-TransmissionCompleteFlag to ensure that the TX is finished.

## **Parameters**

| base   | UART peripheral base address.                 |
|--------|-----------------------------------------------|
| handle | UART handle pointer.                          |
| xfer   | UART transfer structure. See uart_transfer_t. |

### Return values

| kStatus_Success         | Successfully start the data transmission.                                     |
|-------------------------|-------------------------------------------------------------------------------|
| kStatus_UART_TxBusy     | Previous transmission still not finished; data not all written to TX register |
|                         | yet.                                                                          |
| kStatus_InvalidArgument | Invalid argument.                                                             |

## **NXP Semiconductors**

## **UART Driver**

## 11.2.7.26 void UART\_TransferAbortSend ( UART\_Type \* base, uart\_handle\_t \* handle )

This function aborts the interrupt-driven data sending. The user can get the remainBytes to find out how many bytes are not sent out.

169

#### **Parameters**

| base   | UART peripheral base address. |
|--------|-------------------------------|
| handle | UART handle pointer.          |

## 11.2.7.27 status\_t UART\_TransferGetSendCount ( UART\_Type \* base, uart\_handle\_t \* handle, uint32 t \* count )

This function gets the number of bytes written to the UART TX register by using the interrupt method.

#### **Parameters**

| base   | UART peripheral base address. |
|--------|-------------------------------|
| handle | UART handle pointer.          |
| count  | Send bytes count.             |

### Return values

| kStatus_NoTransferIn-<br>Progress | No send in progress.                          |
|-----------------------------------|-----------------------------------------------|
| kStatus_InvalidArgument           | The parameter is invalid.                     |
| kStatus_Success                   | Get successfully through the parameter count; |

## 11.2.7.28 status\_t UART\_TransferReceiveNonBlocking ( UART\_Type \* base, uart\_handle\_t \* handle, uart\_transfer\_t \* xfer, size\_t \* receivedBytes )

This function receives data using an interrupt method. This is a non-blocking function, which returns without waiting for all data to be received. If the RX ring buffer is used and not empty, the data in the ring buffer is copied and the parameter receivedBytes shows how many bytes are copied from the ring buffer. After copying, if the data in the ring buffer is not enough to read, the receive request is saved by the UART driver. When the new data arrives, the receive request is serviced first. When all data is received, the UART driver notifies the upper layer through a callback function and passes the status parameter k-Status\_UART\_RxIdle. For example, the upper layer needs 10 bytes but there are only 5 bytes in the ring buffer. The 5 bytes are copied to the xfer->data and this function returns with the parameter received-Bytes set to 5. For the left 5 bytes, newly arrived data is saved from the xfer->data[5]. When 5 bytes are received, the UART driver notifies the upper layer. If the RX ring buffer is not enabled, this function enables the RX and RX interrupt to receive data to the xfer->data. When all data is received, the upper layer is notified.

## **UART Driver**

### **Parameters**

| base          | UART peripheral base address.                 |
|---------------|-----------------------------------------------|
| handle        | UART handle pointer.                          |
| xfer          | UART transfer structure, see uart_transfer_t. |
| receivedBytes | Bytes received from the ring buffer directly. |

## Return values

| kStatus_Success         | Successfully queue the transfer into transmit queue. |
|-------------------------|------------------------------------------------------|
| kStatus_UART_RxBusy     | Previous receive request is not finished.            |
| kStatus_InvalidArgument | Invalid argument.                                    |

## 11.2.7.29 void UART\_TransferAbortReceive ( UART\_Type \* base, uart\_handle\_t \* handle )

This function aborts the interrupt-driven data receiving. The user can get the remainBytes to know how many bytes are not received yet.

## Parameters

| base   | UART peripheral base address. |
|--------|-------------------------------|
| handle | UART handle pointer.          |

# 11.2.7.30 status\_t UART\_TransferGetReceiveCount ( UART\_Type \* base, uart\_handle\_t \* handle, uint32\_t \* count )

This function gets the number of bytes that have been received.

### **Parameters**

| base   | UART peripheral base address. |
|--------|-------------------------------|
| handle | UART handle pointer.          |
| count  | Receive bytes count.          |

#### Return values

| kStatus_NoTransferIn-   | No receive in progress.                       |
|-------------------------|-----------------------------------------------|
| Progress                |                                               |
| kStatus_InvalidArgument | Parameter is invalid.                         |
| kStatus_Success         | Get successfully through the parameter count; |

## 11.2.7.31 void UART\_TransferHandleIRQ ( UART\_Type \* base, uart\_handle\_t \* handle )

This function handles the UART transmit and receive IRQ request.

#### **Parameters**

| base   | UART peripheral base address. |
|--------|-------------------------------|
| handle | UART handle pointer.          |

# 11.2.7.32 static void UART\_EnableTxDMA ( UART\_Type \* base, bool enable ) [inline], [static]

This function enables or disables the transmit request when the transmitter has one or more slots available in the TxFIFO. The fill level in the TxFIFO that generates the DMA request is controlled by the TXTL bits.

### **Parameters**

| base   | UART peripheral base address.     |
|--------|-----------------------------------|
| enable | True to enable, false to disable. |

## 11.2.7.33 static void UART\_EnableRxDMA ( UART\_Type \* base, bool enable ) [inline], [static]

This function enables or disables the receive request when the receiver has data in the RxFIFO. The fill level in the RxFIFO at which a DMA request is generated is controlled by the RXTL bits.

Parameters

## **UART Driver**

| base   | UART peripheral base address.     |
|--------|-----------------------------------|
| enable | True to enable, false to disable. |

## 11.2.7.34 static void UART\_SetTxFifoWatermark ( UART\_Type \* base, uint8\_t watermark ) [inline], [static]

A maskable interrupt is generated whenever the data level in the TxFIFO falls below the Tx FIFO watermark.

### **Parameters**

| base      | UART base pointer.     |
|-----------|------------------------|
| watermark | The Tx FIFO watermark. |

## 11.2.7.35 static void UART\_SetRxFifoWatermark ( UART\_Type \* base, uint8\_t watermark ) [inline], [static]

A maskable interrupt is generated whenever the data level in the RxFIFO reaches the Rx FIFO watermark.

#### **Parameters**

| base      | UART base pointer.     |
|-----------|------------------------|
| watermark | The Rx FIFO watermark. |

## 11.2.7.36 static void UART\_EnableAutoBaudRate ( UART\_Type \* base, bool enable ) [inline], [static]

## **Parameters**

| base   | UART base pointer.                                                                                                                                                    |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| enable | Enable/Disable Automatic Baud Rate Detection feature.  • true: Enable Automatic Baud Rate Detection feature.  • false: Disable Automatic Baud Rate Detection feature. |

## 11.2.7.37 static bool UART\_IsAutoBaudRateComplete ( UART\_Type \* base ) [inline], [static]

## **MCUXpresso SDK API Reference Manual**

## Parameters

| base   UART base pointer. | base | UART base pointer. |
|---------------------------|------|--------------------|
|---------------------------|------|--------------------|

## Returns

- true: Automatic baud rate detection has finished.
  - false: Automatic baud rate detection has not finished.

## **UART Driver**

## 11.2.8 Variable Documentation

- 11.2.8.1 uint32\_t uart\_config\_t::baudRate\_Bps
- 11.2.8.2 uart\_parity\_mode\_t uart\_config\_t::parityMode
- 11.2.8.3 uart\_stop\_bit\_count\_t uart\_config\_t::stopBitCount
- 11.2.8.4 uint8\_t\* uart\_transfer\_t::data
- 11.2.8.5 size t uart transfer t::dataSize
- 11.2.8.6 uint8\_t\* volatile uart\_handle\_t::txData
- 11.2.8.7 volatile size t uart handle t::txDataSize
- 11.2.8.8 size t uart handle t::txDataSizeAll
- 11.2.8.9 uint8\_t\* volatile uart\_handle\_t::rxData
- 11.2.8.10 volatile size\_t uart\_handle\_t::rxDataSize
- 11.2.8.11 size t uart handle t::rxDataSizeAll
- 11.2.8.12 uint8 t\* uart handle t::rxRingBuffer
- 11.2.8.13 size t uart handle t::rxRingBufferSize
- 11.2.8.14 volatile uint16\_t uart\_handle\_t::rxRingBufferHead
- 11.2.8.15 volatile uint16 t uart handle t::rxRingBufferTail
- 11.2.8.16 uart\_transfer\_callback\_t uart\_handle t::callback
- 11.2.8.17 void\* uart\_handle\_t::userData
- 11.2.8.18 volatile uint8\_t uart\_handle\_t::txState

## 11.3 UART FreeRTOS Driver

## 11.3.1 Overview

## **Data Structures**

• struct uart\_rtos\_config\_t

UART configuration structure. More...

## **Driver version**

• #define FSL\_UART\_FREERTOS\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 0)) *UART freertos driver version 2.0.0.* 

## **UART RTOS Operation**

• int UART\_RTOS\_Init (uart\_rtos\_handle\_t \*handle, uart\_handle\_t \*t\_handle, const uart\_rtos\_config\_t \*cfg)

Initializes a UART instance for operation in RTOS.

• int UART\_RTOS\_Deinit (uart\_rtos\_handle\_t \*handle)

Deinitializes a UART instance for operation.

## **UART transactional Operation**

- int UART\_RTOS\_Send (uart\_rtos\_handle\_t \*handle, const uint8\_t \*buffer, uint32\_t length) Sends data in the background.
- int UART\_RTOS\_Receive (uart\_rtos\_handle\_t \*handle, uint8\_t \*buffer, uint32\_t length, size\_t \*received)

Receives data.

### 11.3.2 Data Structure Documentation

## 11.3.2.1 struct uart\_rtos\_config\_t

## **Data Fields**

• UART\_Type \* base

UART base address.

• uint32 t srcclk

UART source clock in Hz.

• uint32 t baudrate

Desired communication speed.

• uart\_parity\_mode\_t parity

Parity setting.

## MCUXpresso SDK API Reference Manual

## **UART FreeRTOS Driver**

• uart\_stop\_bit\_count\_t stopbits

Number of stop bits to use.

• uint8\_t \* buffer

Buffer for background reception.

• uint32\_t buffer\_size

Size of buffer for background reception.

## 11.3.3 Macro Definition Documentation

## 11.3.3.1 #define FSL\_UART\_FREERTOS\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 0))

## 11.3.4 Function Documentation

## 11.3.4.1 int UART\_RTOS\_Init ( uart\_rtos\_handle\_t \* handle, uart\_handle\_t \* t\_handle, const uart\_rtos\_config\_t \* cfg )

### **Parameters**

| handle   | The RTOS UART handle, the pointer to an allocated space for RTOS context.           |
|----------|-------------------------------------------------------------------------------------|
| t_handle | The pointer to the allocated space to store the transactional layer internal state. |
| cfg      | The pointer to the parameters required to configure the UART after initialization.  |

### Returns

0 succeed; otherwise fail.

## 11.3.4.2 int UART\_RTOS\_Deinit ( uart\_rtos\_handle\_t \* handle )

This function deinitializes the UART module, sets all register values to reset value, and frees the resources.

### **Parameters**

| handle | The RTOS UART handle. |
|--------|-----------------------|
|--------|-----------------------|

## 11.3.4.3 int UART\_RTOS\_Send ( uart\_rtos\_handle\_t \* handle, const uint8\_t \* buffer, uint32\_t length )

This function sends data. It is a synchronous API. If the hardware buffer is full, the task is in the blocked state.

## MCUXpresso SDK API Reference Manual

## **Parameters**

| handle | The RTOS UART handle.              |
|--------|------------------------------------|
| buffer | The pointer to the buffer to send. |
| length | The number of bytes to send.       |

# 11.3.4.4 int UART\_RTOS\_Receive ( uart\_rtos\_handle\_t \* handle, uint8\_t \* buffer, uint32\_t length, size\_t \* received )

This function receives data from UART. It is a synchronous API. If data is immediately available, it is returned immediately and the number of bytes received.

## **Parameters**

| handle   | The RTOS UART handle.                                                            |
|----------|----------------------------------------------------------------------------------|
| buffer   | The pointer to the buffer to write received data.                                |
| length   | The number of bytes to receive.                                                  |
| received | The pointer to a variable of size_t where the number of received data is filled. |

## **UART FreeRTOS Driver**

## Chapter 12

**MU: Messaging Unit** 

## 12.1 Overview

The MCUXpresso SDK provides a driver for the MU module of MCUXpresso SDK devices.

## 12.2 Function description

The MU driver provides these functions:

- Functions to initialize the MU module.
- Functions to send and receive messages.
- Functions for MU flags for both MU sides.
- Functions for status flags and interrupts.
- Other miscellaneous functions.

## 12.2.1 MU initialization

The function MU\_Init() initializes the MU module and enables the MU clock. It should be called before any other MU functions.

The function MU\_Deinit() deinitializes the MU module and disables the MU clock. No MU functions can be called after this function.

## 12.2.2 MU message

The MU message must be sent when the transmit register is empty. The MU driver provides blocking API and non-blocking API to send message.

The MU\_SendMsgNonBlocking() function writes a message to the MU transmit register without checking the transmit register status. The upper layer should check that the transmit register is empty before calling this function. This function can be used in the ISR for better performance.

The MU\_SendMsg() function is a blocking function. It waits until the transmit register is empty and sends the message.

Correspondingly, there are blocking and non-blocking APIs for receiving a message. The MU\_ReadMsg-NonBlocking() function is a non-blocking API. The MU\_ReadMsg() function is the blocking API.

## **Function description**

## 12.2.3 MU flags

The MU driver provides 3-bit general purpose flags. When the flags are set on one side, they are reflected on the other side.

The MU flags must be set when the previous flags have been updated to the other side. The MU driver provides a non-blocking function and a blocking function. The blocking function MU\_SetFlags() waits until previous flags have been updated to the other side and then sets flags. The non-blocking function sets the flags directly. Ensure that the kMU\_FlagsUpdatingFlag is not pending before calling this function.

The function MU\_GetFlags() gets the MU flags on the current side.

## 12.2.4 Status and interrupt

The function MU\_GetStatusFlags() returns all MU status flags. Use the \_mu\_status\_flags to check for specific flags, for example, to check RX0 and RX1 register full, use the following code:

Refer to the driver examples codes located at <SDK\_ROOT>/boards/<BOARD>/driver\_examples/mu The receive full flags are cleared automatically after messages are read out. The transmit empty flags are cleared automatically after new messages are written to the transmit register. The general purpose interrupt flags must be cleared manually using the function MU\_ClearStatusFlags().

Refer to the driver examples codes located at <SDK\_ROOT>/boards/<BOARD>/driver\_examples/mu To enable or disable a specific interrupt, use MU\_EnableInterrupts() and MU\_DisableInterrupts() functions. The interrupts to enable or disable should be passed in as a bit mask of the \_mu\_interrupt\_enable.

The MU\_TriggerInterrupts() function triggers general purpose interrupts and NMI to the other core. The interrupts to trigger are passed in as a bit mask of the \_mu\_interrupt\_trigger. If previously triggered interrupts have not been processed by the other side, this function returns an error.

## 12.2.5 MU misc functions

The MU\_BootCoreB() and MU\_HoldCoreBReset() functions should only be used from A side. They are used to boot the core B or to hold core B in reset.

The MU\_ResetBothSides() function resets MU at both A and B sides. However, only the A side can call this function.

If a core enters stop mode, the platform clock of this core is disabled by default. The function MU\_Set-ClockOnOtherCoreEnable() forces the other core's platform clock to remain enabled even after that core has entered a stop mode. In this case, the other core's platform clock keeps running until the current core enters stop mode too.

Function MU\_GetOtherCorePowerMode() gets the power mode of the other core.

## **Enumerations**

```
enum _mu_status_flags {
 kMU Tx0EmptyFlag = (1U \ll (MU SR TEn SHIFT + 3U)),
 kMU Tx1EmptyFlag = (1U << (MU SR TEn SHIFT + 2U)),
 kMU_Tx2EmptyFlag = (1U << (MU_SR_TEn_SHIFT + 1U)),
 kMU Tx3EmptyFlag = (1U \ll (MU SR TEn SHIFT + 0U)),
 kMU Rx0FullFlag = (1U << (MU SR RFn SHIFT + 3U)),
 kMU_Rx1FullFlag = (1U << (MU_SR_RFn_SHIFT + 2U)),
 kMU_Rx2FullFlag = (1U \ll (MU_SR_RFn_SHIFT + 1U)),
 kMU_Rx3FullFlag = (1U << (MU_SR_RFn_SHIFT + 0U)),
 kMU GenIntOFlag = (1U << (MU SR GIPn SHIFT + 3U)),
 kMU GenInt1Flag = (1U << (MU SR GIPn SHIFT + 2U)),
 kMU_GenInt2Flag = (1U << (MU_SR_GIPn_SHIFT + 1U)),
 kMU GenInt3Flag = (1U << (MU SR GIPn SHIFT + 0U)),
 kMU_EventPendingFlag = MU_SR_EP_MASK,
 kMU_FlagsUpdatingFlag = MU_SR_FUP_MASK }
    MU status flags.
• enum _mu_interrupt_enable {
 kMU Tx0EmptyInterruptEnable = (1U << (MU CR TIEn SHIFT + 3U)),
 kMU Tx1EmptyInterruptEnable = (1U << (MU CR TIEn SHIFT + 2U)),
 kMU_Tx2EmptyInterruptEnable = (1U << (MU_CR_TIEn_SHIFT + 1U)),
 kMU Tx3EmptyInterruptEnable = (1U << (MU CR TIEn SHIFT + 0U)),
 kMU Rx0FullInterruptEnable = (1U << (MU CR RIEn SHIFT + 3U)),
 kMU_Rx1FullInterruptEnable = (1U << (MU_CR_RIEn_SHIFT + 2U)),
 kMU_Rx2FullInterruptEnable = (1U << (MU_CR_RIEn_SHIFT + 1U)),
 kMU Rx3FullInterruptEnable = (1U << (MU CR RIEn SHIFT + 0U)),
 kMU GenInt0InterruptEnable = (1U << (MU CR GIEn SHIFT + 3U)),
 kMU_GenInt1InterruptEnable = (1U << (MU_CR_GIEn_SHIFT + 2U)),
 kMU_GenInt2InterruptEnable = (1U << (MU_CR_GIEn_SHIFT + 1U)),
 kMU GenInt3InterruptEnable = (1U << (MU CR GIEn SHIFT + 0U)) }
    MU interrupt source to enable.
enum _mu_interrupt_trigger {
 kMU_NmiInterruptTrigger = MU_CR_NMI_MASK,
 kMU_GenInt0InterruptTrigger = (1U << (MU_CR_GIRn_SHIFT + 3U)),
 kMU GenInt1InterruptTrigger = (1U << (MU CR GIRn SHIFT + 2U)),
 kMU_GenInt2InterruptTrigger = (1U << (MU_CR_GIRn_SHIFT + 1U)),
 kMU GenInt3InterruptTrigger = (1U << (MU CR GIRn SHIFT + 0U)) }
    MU interrupt that could be triggered to the other core.
```

## **Driver version**

• #define FSL\_MU\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 2)) *MU driver version 2.0.2.* 

MCUXpresso SDK API Reference Manual

## **Function description**

## MU initialization.

• void MU\_Init (MU\_Type \*base)

Initializes the MU module.

• void MU\_Deinit (MU\_Type \*base)

De-initializes the MU module.

## **MU Message**

- static void MU\_SendMsgNonBlocking (MU\_Type \*base, uint32\_t regIndex, uint32\_t msg) Writes a message to the TX register.
- void MU\_SendMsg (MU\_Type \*base, uint32\_t regIndex, uint32\_t msg)

Blocks to send a message.

• static uint32\_t MU\_ReceiveMsgNonBlocking (MU\_Type \*base, uint32\_t regIndex)

Reads a message from the RX register.

• uint32\_t MU\_ReceiveMsg (MU\_Type \*base, uint32\_t regIndex)

Blocks to receive a message.

## **MU Flags**

• static void MU\_SetFlagsNonBlocking (MU\_Type \*base, uint32\_t flags)

Sets the 3-bit MU flags reflect on the other MU side.

• void MU\_SetFlags (MU\_Type \*base, uint32\_t flags)

Blocks setting the 3-bit MU flags reflect on the other MU side.

• static uint32\_t MU\_GetFlags (MU\_Type \*base)

Gets the current value of the 3-bit MU flags set by the other side.

## Status and Interrupt.

• static uint32\_t MU\_GetStatusFlags (MU\_Type \*base)

Gets the MU status flags.

• static void MU ClearStatusFlags (MU Type \*base, uint32 t mask)

Clears the specific MU status flags.

• static void MU\_EnableInterrupts (MU\_Type \*base, uint32\_t mask)

Enables the specific MU interrupts.

• static void MU\_DisableInterrupts (MU\_Type \*base, uint32\_t mask)

Disables the specific MU interrupts.

• status t MU TriggerInterrupts (MU Type \*base, uint32 t mask)

*Triggers interrupts to the other core.* 

static void MU\_ClearNmi (MU\_Type \*base)

Clear non-maskable interrupt (NMI) sent by the other core.

## **MU** misc functions

• void MU\_BootCoreB (MU\_Type \*base, mu\_core\_boot\_mode\_t mode)

Boots the core at B side.

• static void MU HoldCoreBReset (MU Type \*base)

Holds the core reset of B side.

• void MU\_BootOtherCore (MU\_Type \*base, mu\_core\_boot\_mode\_t mode)

Boots the other core.

• static void MU\_HoldOtherCoreReset (MU\_Type \*base)

## **Enumeration Type Documentation**

Holds the other core reset.

static void MU\_ResetBothSides (MU\_Type \*base)

Resets the MU for both A side and B side.

• void MU\_HardwareResetOtherCore (MU\_Type \*base, bool waitReset, bool holdReset, mu\_core\_boot\_mode\_t bootMode)

Hardware reset the other core.

• static void MU\_SetClockOnOtherCoreEnable (MU\_Type \*base, bool enable)

Enables or disables the clock on the other core.

• static mu\_power\_mode\_t MU\_GetOtherCorePowerMode (MU\_Type \*base) Gets the power mode of the other core.

## 12.3 Macro Definition Documentation

## 12.3.1 #define FSL\_MU\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 2))

## 12.4 Enumeration Type Documentation

## 12.4.1 enum mu status flags

## Enumerator

```
kMU_Tx1EmptyFlag TX1 empty.
kMU_Tx2EmptyFlag TX2 empty.
kMU_Tx3EmptyFlag TX3 empty.
kMU_Tx3EmptyFlag TX3 empty.
kMU_Rx0FullFlag RX0 full.
kMU_Rx1FullFlag RX1 full.
kMU_Rx2FullFlag RX2 full.
kMU_Rx3FullFlag RX3 full.
kMU_GenInt0Flag General purpose interrupt 0 pending.
kMU_GenInt2Flag General purpose interrupt 0 pending.
kMU_GenInt3Flag General purpose interrupt 0 pending.
kMU_EventPendingFlag MU event pending.
kMU_FlagsUpdatingFlag MU flags update is on-going.
```

## 12.4.2 enum \_mu\_interrupt\_enable

#### Enumerator

```
    kMU_Tx0EmptyInterruptEnable TX0 empty.
    kMU_Tx1EmptyInterruptEnable TX1 empty.
    kMU_Tx2EmptyInterruptEnable TX2 empty.
    kMU_Tx3EmptyInterruptEnable TX3 empty.
    kMU_Rx0FullInterruptEnable RX0 full.
    kMU_Rx1FullInterruptEnable RX1 full.
```

## MCUXpresso SDK API Reference Manual

kMU\_Rx2FullInterruptEnable
 kMU\_Rx3FullInterruptEnable
 kMU\_GenInt0InterruptEnable
 kMU\_GenInt1InterruptEnable
 kMU\_GenInt2InterruptEnable
 kMU\_GenInt3InterruptEnable
 General purpose interrupt 2.
 General purpose interrupt 3.

## 12.4.3 enum mu\_interrupt\_trigger

### Enumerator

```
    kMU_NmiInterruptTrigger NMI interrupt.
    kMU_GenInt0InterruptTrigger General purpose interrupt 0.
    kMU_GenInt1InterruptTrigger General purpose interrupt 1.
    kMU_GenInt2InterruptTrigger General purpose interrupt 2.
    kMU_GenInt3InterruptTrigger General purpose interrupt 3.
```

## 12.5 Function Documentation

## 12.5.1 void MU\_Init ( MU\_Type \* base )

This function enables the MU clock only.

**Parameters** 

| base | MU peripheral base address. |
|------|-----------------------------|
|------|-----------------------------|

## 12.5.2 void MU\_Deinit ( MU\_Type \* base )

This function disables the MU clock only.

**Parameters** 

```
base MU peripheral base address.
```

# 12.5.3 static void MU\_SendMsgNonBlocking ( MU\_Type \* base, uint32\_t regIndex, uint32\_t msg ) [inline], [static]

This function writes a message to the specific TX register. It does not check whether the TX register is empty or not. The upper layer should make sure the TX register is empty before calling this function. This function can be used in ISR for better performance.

### MCUXpresso SDK API Reference Manual

185

```
* while (!(kMU_Tx0EmptyFlag & MU_GetStatusFlags(base))) { } // Wait for
          TX0 register empty.
* MU_SendMsgNonBlocking(base, OU, MSG_VAL); // Write message to the TX0 register.
*
```

#### **Parameters**

| base     | MU peripheral base address. |
|----------|-----------------------------|
| regIndex | TX register index.          |
| msg      | Message to send.            |

## 12.5.4 void MU\_SendMsg ( MU\_Type \* base, uint32\_t regIndex, uint32\_t msg )

This function waits until the TX register is empty and sends the message.

#### **Parameters**

| base     | MU peripheral base address. |
|----------|-----------------------------|
| regIndex | TX register index.          |
| msg      | Message to send.            |

# 12.5.5 static uint32\_t MU\_ReceiveMsgNonBlocking ( MU\_Type \* base, uint32\_t regIndex ) [inline], [static]

This function reads a message from the specific RX register. It does not check whether the RX register is full or not. The upper layer should make sure the RX register is full before calling this function. This function can be used in ISR for better performance.

```
* uint32_t msg;
* while (!(kMU_Rx0FullFlag & MU_GetStatusFlags(base)))
* {
* } // Wait for the RX0 register full.
*
* msg = MU_ReceiveMsgNonBlocking(base, 0U); // Read message from RX0 register.
*
```

## **Parameters**

| base     | MU peripheral base address. |
|----------|-----------------------------|
| regIndex | TX register index.          |

### Returns

The received message.

## 12.5.6 uint32\_t MU\_ReceiveMsg ( MU\_Type \* base, uint32\_t regIndex )

This function waits until the RX register is full and receives the message.

### **Parameters**

| base     | MU peripheral base address. |
|----------|-----------------------------|
| regIndex | RX register index.          |

## Returns

The received message.

# 12.5.7 static void MU\_SetFlagsNonBlocking ( MU\_Type \* base, uint32\_t flags ) [inline], [static]

This function sets the 3-bit MU flags directly. Every time the 3-bit MU flags are changed, the status flag kMU\_FlagsUpdatingFlag asserts indicating the 3-bit MU flags are updating to the other side. After the 3-bit MU flags are updated, the status flag kMU\_FlagsUpdatingFlag is cleared by hardware. During the flags updating period, the flags cannot be changed. The upper layer should make sure the status flag kMU\_FlagsUpdatingFlag is cleared before calling this function.

```
* while (kMU_FlagsUpdatingFlag & MU_GetStatusFlags(base))
* {
* } // Wait for previous MU flags updating.
*
* MU_SetFlagsNonBlocking(base, OU); // Set the mU flags.
*
```

#### **Parameters**

| base  | MU peripheral base address. |
|-------|-----------------------------|
| flags | The 3-bit MU flags to set.  |

## 12.5.8 void MU\_SetFlags ( MU\_Type \* base, uint32\_t flags )

This function blocks setting the 3-bit MU flags. Every time the 3-bit MU flags are changed, the status flag kMU\_FlagsUpdatingFlag asserts indicating the 3-bit MU flags are updating to the other side. After the 3-bit MU flags are updated, the status flag kMU\_FlagsUpdatingFlag is cleared by hardware. During the flags updating period, the flags cannot be changed. This function waits for the MU status flag kMU\_FlagsUpdatingFlag cleared and sets the 3-bit MU flags.

## **Parameters**

| base  | MU peripheral base address. |
|-------|-----------------------------|
| flags | The 3-bit MU flags to set.  |

## 12.5.9 static uint32\_t MU\_GetFlags ( MU\_Type \* base ) [inline], [static]

This function gets the current 3-bit MU flags on the current side.

## Parameters

| base | MU peripheral base address. |
|------|-----------------------------|

#### Returns

flags Current value of the 3-bit flags.

# 12.5.10 static uint32\_t MU\_GetStatusFlags ( MU\_Type \* base ) [inline], [static]

This function returns the bit mask of the MU status flags. See \_mu\_status\_flags.

## MCUXpresso SDK API Reference Manual

```
* // The TX1 register is empty. Message can be sent.
* MU_SendMsgNonBlocking(base, 1U, MSG1_VAL);
* }
*
```

#### **Parameters**

| base | MU peripheral base address. |
|------|-----------------------------|
|------|-----------------------------|

## Returns

Bit mask of the MU status flags, see \_mu\_status\_flags.

# 12.5.11 static void MU\_ClearStatusFlags ( MU\_Type \* base, uint32\_t mask ) [inline], [static]

This function clears the specific MU status flags. The flags to clear should be passed in as bit mask. See \_mu\_status\_flags.

## **Parameters**

| mask Bit mask of the MU status flags. See _mu_status_flags. The following flags are cleared by hardware, this function could not clear them.  • kMU_Tx0EmptyFlag  • kMU_Tx1EmptyFlag  • kMU_Tx2EmptyFlag  • kMU_Tx3EmptyFlag  • kMU_Rx0FullFlag  • kMU_Rx1FullFlag  • kMU_Rx2FullFlag  • kMU_Rx3FullFlag  • kMU_ExentPendingFlag | base | MU peripheral base address.                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul><li> kMU_FlagsUpdatingFlag</li><li> kMU_OtherSideInResetFlag</li></ul>                                                                                                                                                                                                                                                       | _    | Bit mask of the MU status flags. See _mu_status_flags. The following flags are cleared by hardware, this function could not clear them.  • kMU_Tx0EmptyFlag  • kMU_Tx1EmptyFlag  • kMU_Tx2EmptyFlag  • kMU_Tx3EmptyFlag  • kMU_Rx0FullFlag  • kMU_Rx1FullFlag  • kMU_Rx2FullFlag  • kMU_Rx2FullFlag  • kMU_Rx3FullFlag  • kMU_Rx3FullFlag  • kMU_Rx3FullFlag  • kMU_Fx3FullFlag  • kMU_Fx3FullFlag  • kMU_Fx3FullFlag |

# 12.5.12 static void MU\_EnableInterrupts ( MU\_Type \* base, uint32\_t mask ) [inline], [static]

This function enables the specific MU interrupts. The interrupts to enable should be passed in as bit mask. See \_mu\_interrupt\_enable.

#### **Parameters**

| base | MU peripheral base address.                              |
|------|----------------------------------------------------------|
| mask | Bit mask of the MU interrupts. See _mu_interrupt_enable. |

# 12.5.13 static void MU\_DisableInterrupts ( MU\_Type \* base, uint32\_t mask ) [inline], [static]

This function disables the specific MU interrupts. The interrupts to disable should be passed in as bit mask. See \_mu\_interrupt\_enable.

### **Parameters**

| base | MU peripheral base address.                              |
|------|----------------------------------------------------------|
| mask | Bit mask of the MU interrupts. See _mu_interrupt_enable. |

## 12.5.14 status\_t MU\_TriggerInterrupts ( MU\_Type \* base, uint32\_t mask )

This function triggers the specific interrupts to the other core. The interrupts to trigger are passed in as bit mask. See <u>\_mu\_interrupt\_trigger</u>. The MU should not trigger an interrupt to the other core when the previous interrupt has not been processed by the other core. This function checks whether the previous interrupts have been processed. If not, it returns an error.

MCUXpresso SDK API Reference Manual

### **Parameters**

| base | MU peripheral base address.                                       |
|------|-------------------------------------------------------------------|
| mask | Bit mask of the interrupts to trigger. See _mu_interrupt_trigger. |

## Return values

| kStatus_Success | Interrupts have been triggered successfully. |
|-----------------|----------------------------------------------|
| kStatus_Fail    | Previous interrupts have not been accepted.  |

## 12.5.15 static void MU ClearNmi ( MU Type \* base ) [inline], [static]

This function clears non-maskable interrupt (NMI) sent by the other core.

### **Parameters**

| base | MU peripheral base address. |
|------|-----------------------------|

## 12.5.16 void MU\_BootCoreB ( MU\_Type \* base, mu\_core\_boot\_mode\_t mode )

This function sets the B side core's boot configuration and releases the core from reset.

### **Parameters**

| base | MU peripheral base address. |
|------|-----------------------------|
| mode | Core B boot mode.           |

## Note

Only MU side A can use this function.

# 12.5.17 static void MU\_HoldCoreBReset ( MU\_Type \* base ) [inline], [static]

This function causes the core of B side to be held in reset following any reset event.

### **Parameters**

| base | MU peripheral base address. |
|------|-----------------------------|
|------|-----------------------------|

Note

Only A side could call this function.

# 12.5.18 void MU\_BootOtherCore ( MU\_Type \* base, mu\_core\_boot\_mode\_t mode )

This function boots the other core with a boot configuration.

### **Parameters**

| base | MU peripheral base address. |
|------|-----------------------------|
| mode | The other core boot mode.   |

### 

This function causes the other core to be held in reset following any reset event.

**Parameters** 

| base | MU peripheral base address. |
|------|-----------------------------|

## 

This function resets the MU for both A side and B side. Before reset, it is recommended to interrupt processor B, because this function may affect the ongoing processor B programs.

Parameters

MCUXpresso SDK API Reference Manual

| base | MU peripheral base address. |
|------|-----------------------------|
|------|-----------------------------|

### Note

For some platforms, only MU side A could use this function, check reference manual for details.

# 12.5.21 void MU\_HardwareResetOtherCore ( MU\_Type \* base, bool waitReset, bool holdReset, mu\_core\_boot\_mode\_t bootMode )

This function resets the other core, the other core could mask the hardware reset by calling MU\_Mask-HardwareReset. The hardware reset mask feature is only available for some platforms. This function could be used together with MU\_BootOtherCore to control the other core reset workflow.

Example 1: Reset the other core, and no hold reset

```
* MU_HardwareResetOtherCore(MU_A, true, false, bootMode);
```

In this example, the core at MU side B will reset with the specified boot mode.

Example 2: Reset the other core and hold it, then boot the other core later.

```
* // Here the other core enters reset, and the reset is hold
* MU_HardwareResetOtherCore(MU_A, true, true, modeDontCare);
* // Current core boot the other core when necessary.
* MU_BootOtherCore(MU_A, bootMode);
```

#### **Parameters**

| base      | MU peripheral base address.                                                                                                                                                                                                             |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| waitReset | <ul> <li>Wait the other core enters reset.</li> <li>true: Wait until the other core enters reset, if the other core has masked the hardware reset, then this function will be blocked.</li> <li>false: Don't wait the reset.</li> </ul> |

| holdReset | <ul> <li>Hold the other core reset or not.</li> <li>true: Hold the other core in reset, this function returns directly when the other core enters reset.</li> <li>false: Don't hold the other core in reset, this function waits until the other core out of reset.</li> </ul> |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bootMode  | Boot mode of the other core, if holdReset is true, this parameter is useless.                                                                                                                                                                                                  |

# 12.5.22 static void MU\_SetClockOnOtherCoreEnable ( MU\_Type \* base, bool enable ) [inline], [static]

This function enables or disables the platform clock on the other core when that core enters a stop mode. If disabled, the platform clock for the other core is disabled when it enters stop mode. If enabled, the platform clock keeps running on the other core in stop mode, until this core also enters stop mode.

### **Parameters**

| base   | MU peripheral base address.                    |
|--------|------------------------------------------------|
| enable | Enable or disable the clock on the other core. |

# 12.5.23 static mu\_power\_mode\_t MU\_GetOtherCorePowerMode ( MU\_Type \* base ) [inline], [static]

This function gets the power mode of the other core.

### **Parameters**

| base | MU peripheral base address. |
|------|-----------------------------|
|------|-----------------------------|

#### Returns

Power mode of the other core.

# Chapter 13 QSPI: Quad Serial Peripheral Interface Driver

## 13.1 Overview

The MCUXpresso SDK provides a peripheral driver for the Quad Serial Peripheral Interface (QSPI) module of MCUXpresso SDK devices.

QSPI driver includes functional APIs and EDMA transactional APIs.

Functional APIs are feature/property target low level APIs. Functional APIs can be used for QSPI initialization/configuration/operation for optimization/customization purpose. Using the functional API requires the knowledge of the QSPI peripheral and how to organize functional APIs to meet the application requirements. All functional API use the peripheral base address as the first parameter. QSPI functional operation groups provide the functional API set.

Transactional APIs are transaction target high level APIs. Transactional APIs can be used to enable the peripheral and in the application if the code size and performance of transactional APIs satisfy the requirements. If the code size and performance are a critical requirement, see the transactional API implementation and write a custom code. All transactional APIs use the qspi\_handle\_t as the first parameter. Initialize the handle by calling the QSPI\_TransferTxCreateHandleEDMA() or QSPI\_TransferRxCreateHandleEDMA() API.

## **Data Structures**

```
• struct qspi_dqs_config_t
```

DQS configure features. More...

struct qspi\_flash\_timing\_t

Flash timing configuration. More...

• struct qspi\_config\_t

QSPI configuration structure. More...

• struct qspi\_flash\_config\_t

External flash configuration items. More...

struct qspi\_transfer\_t

Transfer structure for QSPI. More...

## **Macros**

• #define QSPI\_LUT\_SEQ(cmd0, pad0, op0, cmd1, pad1, op1)

*Macro functions for LUT table.*• #define QSPI\_CMD (0x1U)

Macro for QSPI LUT command.

• #define QSPI\_PAD\_1 (0x0U)

Macro for QSPI PAD.

## Overview

## **Enumerations**

```
enum _status_t {
 kStatus QSPI Idle = MAKE STATUS(kStatusGroup QSPI, 0),
 kStatus QSPI Busy = MAKE STATUS(kStatusGroup QSPI, 1),
 kStatus_QSPI_Error = MAKE_STATUS(kStatusGroup_QSPI, 2) }
    Status structure of OSPI.
enum qspi_read_area_t {
 kQSPI ReadAHB = 0x0U,
 kQSPI_ReadIP }
    QSPI read data area, from IP FIFO or AHB buffer.
enum qspi_command_seq_t {
 kQSPI_IPSeq = QuadSPI_SPTRCLR_IPPTRC_MASK,
 kOSPI BufferSeg = QuadSPI SPTRCLR BFPTRC MASK }
    OSPI command sequence type.
enum qspi_fifo_t {
 kOSPI TxFifo = QuadSPI MCR CLR TXF MASK,
 kOSPI RxFifo = QuadSPI MCR CLR RXF MASK,
 kQSPI_AllFifo = QuadSPI_MCR_CLR_TXF_MASK | QuadSPI_MCR_CLR_RXF_MASK }
    OSPI buffer type.
enum qspi_endianness_t {
 kQSPI 64BigEndian = 0x0U,
 kQSPI 32LittleEndian,
 kQSPI_32BigEndian,
 kQSPI_64LittleEndian }
    OSPI transfer endianess.
enum _qspi_error_flags {
 kQSPI_DataLearningFail = (int)QuadSPI_FR_DLPFF_MASK,
 kQSPI_TxBufferFill = QuadSPI_FR_TBFF_MASK,
 kQSPI TxBufferUnderrun = QuadSPI FR TBUF MASK,
 kQSPI_IllegalInstruction = QuadSPI_FR_ILLINE_MASK,
 kOSPI RxBufferOverflow = QuadSPI FR RBOF MASK,
 kQSPI_RxBufferDrain = QuadSPI_FR_RBDF_MASK,
 kQSPI AHBSequenceError = QuadSPI FR ABSEF MASK,
 kQSPI AHBBufferOverflow = QuadSPI FR ABOF MASK,
 kQSPI_IPCommandUsageError = QuadSPI_FR_IUEF_MASK,
 kQSPI_IPCommandTriggerDuringAHBAccess = QuadSPI_FR_IPAEF_MASK,
 kQSPI IPCommandTriggerDuringIPAccess = QuadSPI FR IPIEF MASK,
 kQSPI_IPCommandTriggerDuringAHBGrant = QuadSPI_FR_IPGEF_MASK,
 kQSPI_IPCommandTransactionFinished = QuadSPI_FR_TFF_MASK,
 kQSPI_FlagAll = (int)0x8C83F8D1U }
    OSPI error flags.
enum _qspi_flags {
```

197

```
kOSPI DataLearningSamplePoint = (int)QuadSPI SR DLPSMP MASK,
 kQSPI_TxBufferFull = QuadSPI_SR_TXFULL_MASK,
 kOSPI TxBufferEnoughData = QuadSPI SR TXEDA MASK,
 kQSPI_RxDMA = QuadSPI_SR_RXDMA_MASK,
 kQSPI RxBufferFull = QuadSPI SR RXFULL MASK,
 kQSPI_RxWatermark = QuadSPI_SR_RXWE_MASK,
 kQSPI_AHB3BufferFull = QuadSPI_SR_AHB3FUL_MASK,
 kQSPI_AHB2BufferFull = QuadSPI_SR_AHB2FUL_MASK,
 kOSPI AHB1BufferFull = QuadSPI SR AHB1FUL MASK,
 kQSPI_AHB0BufferFull = QuadSPI_SR_AHB0FUL_MASK,
 kQSPI_AHB3BufferNotEmpty = QuadSPI_SR_AHB3NE_MASK,
 kOSPI AHB2BufferNotEmpty = QuadSPI SR AHB2NE MASK,
 kQSPI_AHB1BufferNotEmpty = QuadSPI_SR_AHB1NE_MASK,
 kOSPI AHBOBufferNotEmpty = QuadSPI SR AHBONE MASK,
 kQSPI_AHBTransactionPending = QuadSPI_SR_AHBTRN_MASK,
 kQSPI AHBCommandPriorityGranted = QuadSPI SR AHBGNT MASK,
 kQSPI AHBAccess = QuadSPI SR AHB ACC MASK,
 kQSPI_IPAccess = QuadSPI_SR_IP_ACC_MASK,
 kQSPI_Busy = QuadSPI_SR_BUSY_MASK,
 kQSPI StateAll = (int)0xEF897FE7U }
    OSPI state bit.
enum _qspi_interrupt_enable {
 kQSPI_DataLearningFailInterruptEnable,
 kQSPI_TxBufferFillInterruptEnable = QuadSPI_RSER_TBFIE_MASK,
 kQSPI TxBufferUnderrunInterruptEnable = QuadSPI RSER TBUIE MASK,
 kOSPI IllegalInstructionInterruptEnable,
 kQSPI_RxBufferOverflowInterruptEnable = QuadSPI_RSER_RBOIE_MASK,
 kOSPI RxBufferDrainInterruptEnable = QuadSPI RSER RBDIE MASK,
 kQSPI_AHBSequenceErrorInterruptEnable = QuadSPI_RSER_ABSEIE_MASK,
 kQSPI_AHBBufferOverflowInterruptEnable = QuadSPI_RSER_ABOIE_MASK,
 kQSPI_IPCommandUsageErrorInterruptEnable = QuadSPI_RSER_IUEIE_MASK,
 kQSPI IPCommandTriggerDuringAHBAccessInterruptEnable,
 kQSPI_IPCommandTriggerDuringIPAccessInterruptEnable,
 kOSPI\_IP Command Trigger During AHB Grant Interrupt Enable,
 kQSPI_IPCommandTransactionFinishedInterruptEnable,
 kQSPI AllInterruptEnable = (int)0x8C83F8D1U }
    OSPI interrupt enable.
• enum _qspi_dma_enable { kQSPI_RxBufferDrainDMAEnable = QuadSPI_RSER_RBDDE_MAS-
 K }
    QSPI DMA request flag.
enum qspi_dqs_phrase_shift_t {
 kQSPI_DQSNoPhraseShift = 0x0U,
 kQSPI_DQSPhraseShift45Degree,
 kQSPI_DQSPhraseShift90Degree,
 kQSPI DQSPhraseShift135Degree }
```

NXP Semiconductors

### Overview

Phrase shift number for DQS mode.

## **Driver version**

• #define FSL\_QSPI\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 2)) QSPI driver version 2.0.2.

## Initialization and deinitialization

• uint32\_t QSPI\_GetInstance (QuadSPI\_Type \*base)

Get the instance number for QSPI.

- void QSPI\_Init (QuadSPI\_Type \*base, qspi\_config\_t \*config, uint32\_t srcClock\_Hz)

  Initializes the QSPI module and internal state.
- void QSPI\_GetDefaultQspiConfig (qspi\_config\_t \*config)

Gets default settings for QSPI.

• void QSPI\_Deinit (QuadSPI\_Type \*base)

Deinitializes the QSPI module.

- void QSPI\_SetFlashConfig (QuadSPI\_Type \*base, qspi\_flash\_config\_t \*config)

  Configures the serial flash parameter.
- void QSPI\_SoftwareReset (QuadSPI\_Type \*base)

Software reset for the QSPI logic.

• static void QSPI\_Enable (QuadSPI\_Type \*base, bool enable) Enables or disables the OSPI module.

### Status

• static uint32\_t QSPI\_GetStatusFlags (QuadSPI\_Type \*base)

Gets the state value of QSPI.

• static uint32\_t QSPI\_GetErrorStatusFlags (QuadSPI\_Type \*base)

Gets QSPI error status flags.

• static void QSPI\_ClearErrorFlag (QuadSPI\_Type \*base, uint32\_t mask) Clears the OSPI error flags.

Interrupts

- static void QSPI\_EnableInterrupts (QuadSPI\_Type \*base, uint32\_t mask)

  Enables the OSPI interrupts.
- static void QSPI\_DisableInterrupts (QuadSPI\_Type \*base, uint32\_t mask)

  Disables the QSPI interrupts.

## **DMA Control**

- static void QSPI\_EnableDMA (QuadSPI\_Type \*base, uint32\_t mask, bool enable) Enables the OSPI DMA source.
- static uint32\_t QSPI\_GetTxDataRegisterAddress (QuadSPI\_Type \*base)

  Gets the Tx data register address.
- uint32\_t QSPI\_GetRxDataRegisterAddress (QuadSPI\_Type \*base)

Gets the Rx data register address used for DMA operation.

### **Bus Operations**

- static void QSPI\_SetIPCommandAddress (QuadSPI\_Type \*base, uint32\_t addr)

  Sets the IP command address.
- static void QSPI\_SetIPCommandSize (QuadSPI\_Type \*base, uint32\_t size) Sets the IP command size.
- void QSPI\_ExecuteIPCommand (QuadSPI\_Type \*base, uint32\_t index) Executes IP commands located in LUT table.
- void QSPI\_ExecuteAHBCommand (QuadSPI\_Type \*base, uint32\_t index)

Executes AHB commands located in LUT table.

- static void QSPI\_EnableIPParallelMode (QuadSPI\_Type \*base, bool enable) Enables/disables the QSPI IP command parallel mode.
- static void QSPI\_EnableAHBParallelMode (QuadSPI\_Type \*base, bool enable) Enables/disables the QSPI AHB command parallel mode.
- void QSPI\_UpdateLUT (QuadSPI\_Type \*base, uint32\_t index, uint32\_t \*cmd) Updates the LUT table.
- static void QSPI\_ClearFifo (QuadSPI\_Type \*base, uint32\_t mask) Clears the QSPI FIFO logic.
- static void QSPI\_ClearCommandSequence (QuadSPI\_Type \*base, qspi\_command\_seq\_t seq) @ brief Clears the command sequence for the IP/buffer command.
- static void QSPI\_EnableDDRMode (QuadSPI\_Type \*base, bool enable) Enable or disable DDR mode.
- void QSPI\_SetReadDataArea (QuadSPI\_Type \*base, qspi\_read\_area\_t area) @ brief Set the RX buffer readout area.
- void QSPI\_WriteBlocking (QuadSPI\_Type \*base, uint32\_t \*buffer, size\_t size) Sends a buffer of data bytes using a blocking method.
- static void QSPI\_WriteData (QuadSPI\_Type \*base, uint32\_t data)
  Writes data into FIFO.
- void QSPI\_ReadBlocking (QuadSPI\_Type \*base, uint32\_t \*buffer, size\_t size)
- Receives a buffer of data bytes using a blocking method.
   uint32\_t QSPI\_ReadData (QuadSPI\_Type \*base)

Receives data from data FIFO.

#### **Transactional**

- static void QSPI\_TransferSendBlocking (QuadSPI\_Type \*base, qspi\_transfer\_t \*xfer) Writes data to the QSPI transmit buffer.
- static void QSPI\_TransferReceiveBlocking (QuadSPI\_Type \*base, qspi\_transfer\_t \*xfer)

  Reads data from the QSPI receive buffer in polling way.

#### 13.2 Data Structure Documentation

### 13.2.1 struct qspi\_dqs\_config\_t

#### **Data Fields**

- uint32\_t portADelayTapNum
  - Delay chain tap number selection for QSPI port A DQS.
- uint32\_t portBDelayTapNum

Delay chain tap number selection for QSPI port B DQS.

MCUXpresso SDK API Reference Manual

#### **Data Structure Documentation**

• qspi\_dqs\_phrase\_shift\_t shift

Phase shift for internal DQS generation.

bool enableDQSClkInverse

Enable inverse clock for internal DQS generation.

bool enableDQSPadLoopback

Enable DQS loop back from DQS pad.

• bool enableDQSLoopback

Enable DQS loop back.

### 13.2.2 struct qspi\_flash\_timing\_t

#### **Data Fields**

• uint32 t dataHoldTime

Serial flash data in hold time.

• uint32\_t CSHoldTime

Serial flash CS hold time in terms of serial flash clock cycles.

• uint32\_t CSSetupTime

Serial flash CS setup time in terms of serial flash clock cycles.

### 13.2.3 struct qspi\_config\_t

#### **Data Fields**

• uint32\_t clockSource

Clock source for QSPI module.

• uint32\_t baudRate

Serial flash clock baud rate.

• uint8\_t txWatermark

OSPI transmit watermark value.

• uint8\_t rxWatermark

OSPI receive watermark value.

• uint32\_t AHBbufferSize [FSL\_FEATURE\_QSPI\_AHB\_BUFFER\_COUNT] AHB buffer size.

• uint8\_t AHBbufferMaster [FSL\_FEATURE\_QSPI\_AHB\_BUFFER\_COUNT]

AHB buffer master.

• bool enableAHBbuffer3AllMaster

Is AHB buffer3 for all master.

• qspi\_read\_area\_t area

Which area Rx data readout.

bool enableQspi

Enable QSPI after initialization.

#### 13.2.3.0.0.10 Field Documentation

13.2.3.0.0.10.1 uint8\_t qspi\_config\_t::rxWatermark

13.2.3.0.0.10.2 uint32\_t qspi\_config\_t::AHBbufferSize[FSL\_FEATURE\_QSPI\_AHB\_BUFFER\_COUNT]

13.2.3.0.0.10.3 uint8\_t qspi\_config\_t::AHBbufferMaster[FSL\_FEATURE\_QSPI\_AHB\_BUFFER\_CO-UNT]

13.2.3.0.0.10.4 bool qspi config t::enableAHBbuffer3AllMaster

### 13.2.4 struct qspi\_flash\_config\_t

#### **Data Fields**

• uint32 t flashA1Size

Flash A1 size.

• uint32 t flashA2Size

Flash A2 size.

• uint32 t flashB1Size

Flash B1 size.

uint32\_t flashB2Size

Flash B2 size.

• uint32\_t lookuptable [FSL\_FEATURE\_QSPI\_LUT\_DEPTH]

Flash command in LUT.

• uint32 t dataHoldTime

Data line hold time.

• uint32\_t CSHoldTime

CS line hold time.

• uint32 t CSSetupTime

CS line setup time.

• uint32\_t cloumnspace

Column space size.

• uint32 t dataLearnValue

Data Learn value if enable data learn.

• qspi\_endianness\_t endian

Flash data endianess.

• bool enableWordAddress

If enable word address.

#### **Enumeration Type Documentation**

13.2.4.0.0.11 Field Documentation

13.2.4.0.0.11.1 uint32\_t qspi\_flash\_config\_t::dataHoldTime

13.2.4.0.0.11.2 qspi\_endianness\_t qspi\_flash\_config\_t::endian

13.2.4.0.0.11.3 bool qspi\_flash\_config\_t::enableWordAddress

#### 13.2.5 struct qspi transfer t

#### **Data Fields**

• uint32 t \* data

Pointer to data to transmit.

• size t dataSize

Bytes to be transmit.

#### 13.3 Macro Definition Documentation

13.3.1 #define FSL QSPI DRIVER VERSION (MAKE VERSION(2, 0, 2))

#### 13.4 Enumeration Type Documentation

### 13.4.1 enum \_status\_t

#### Enumerator

kStatus\_QSPI\_Idle QSPI is in idle state.

kStatus\_QSPI\_Busy QSPI is busy.

kStatus\_QSPI\_Error Error occurred during QSPI transfer.

### 13.4.2 enum qspi\_read\_area\_t

#### Enumerator

kQSPI\_ReadAHB QSPI read from AHB buffer.kQSPI\_ReadIP QSPI read from IP FIFO.

### 13.4.3 enum qspi\_command\_seq\_t

#### Enumerator

kQSPI\_IPSeq IP command sequence.kQSPI\_BufferSeq Buffer command sequence.

#### MCUXpresso SDK API Reference Manual

### 13.4.4 enum qspi\_fifo\_t

#### Enumerator

```
kQSPI_TxFifo QSPI Tx FIFO.kQSPI_RxFifo QSPI Rx FIFO.kQSPI_AllFifo QSPI all FIFO, including Tx and Rx.
```

### 13.4.5 enum qspi\_endianness\_t

#### Enumerator

```
kQSPI_64BigEndian 64 bits big endian
kQSPI_32LittleEndian 32 bit little endian
kQSPI_32BigEndian 32 bit big endian
kQSPI 64LittleEndian 64 bit little endian
```

### 13.4.6 enum \_qspi\_error\_flags

#### Enumerator

kQSPI\_DataLearningFail Data learning pattern failure flag.
kQSPI\_TxBufferFill Tx buffer fill flag.
kQSPI\_TxBufferUnderrun Tx buffer underrun flag.
kQSPI\_IllegalInstruction Illegal instruction error flag.
kQSPI\_RxBufferOverflow Rx buffer overflow flag.
kQSPI\_RxBufferDrain Rx buffer drain flag.

kQSPI\_AHBSequenceError AHB sequence error flag.

kQSPI\_AHBBufferOverflow AHB buffer overflow flag.

kQSPI\_IPCommandUsageError IP command usage error flag.

 ${\it kQSPI\_IPCommandTriggerDuringAHBAccess}$  IP command trigger during AHB access error.

kQSPI\_IPCommandTriggerDuringIPAccess IP command trigger cannot be executed.

kQSPI\_IPCommandTriggerDuringAHBGrant IP command trigger during AHB grant error.

kQSPI\_IPCommandTransactionFinished IP command transaction finished flag.

kQSPI\_FlagAll All error flag.

### 13.4.7 enum \_qspi\_flags

#### Enumerator

```
kQSPI_DataLearningSamplePoint Data learning sample point.kQSPI_TxBufferFull Tx buffer full flag.
```

### MCUXpresso SDK API Reference Manual

#### **Enumeration Type Documentation**

kQSPI\_TxBufferEnoughData Tx buffer enough data available.

kQSPI\_RxDMA Rx DMA is requesting or running.

kQSPI\_RxBufferFull Rx buffer full.

kQSPI\_RxWatermark Rx buffer watermark exceeded.

kOSPI AHB3BufferFull AHB buffer 3 full.

kQSPI\_AHB2BufferFull AHB buffer 2 full.

kQSPI\_AHB1BufferFull AHB buffer 1 full.

kQSPI\_AHB0BufferFull AHB buffer 0 full.

kQSPI\_AHB3BufferNotEmpty AHB buffer 3 not empty.

kQSPI\_AHB2BufferNotEmpty AHB buffer 2 not empty.

kQSPI\_AHB1BufferNotEmpty AHB buffer 1 not empty.

kQSPI\_AHB0BufferNotEmpty AHB buffer 0 not empty.

**kQSPI\_AHBTransactionPending** AHB access transaction pending.

kQSPI\_AHBCommandPriorityGranted AHB command priority granted.

kQSPI\_AHBAccess AHB access.

kOSPI IPAccess IP access.

*kQSPI\_Busy* Module busy.

kQSPI\_StateAll All flags.

### 13.4.8 enum \_qspi\_interrupt\_enable

#### Enumerator

kQSPI\_DataLearningFailInterruptEnable Data learning pattern failure interrupt enable.

kQSPI\_TxBufferFillInterruptEnable Tx buffer fill interrupt enable.

kQSPI\_TxBufferUnderrunInterruptEnable Tx buffer underrun interrupt enable.

kOSPI IllegalInstructionInterruptEnable Illegal instruction error interrupt enable.

kQSPI\_RxBufferOverflowInterruptEnable Rx buffer overflow interrupt enable.

kQSPI\_RxBufferDrainInterruptEnable Rx buffer drain interrupt enable.

kQSPI\_AHBSequenceErrorInterruptEnable AHB sequence error interrupt enable.

kQSPI\_AHBBufferOverflowInterruptEnable AHB buffer overflow interrupt enable.

kQSPI\_IPCommandUsageErrorInterruptEnable IP command usage error interrupt enable.

**kQSPI\_IPCommandTriggerDuringAHBAccessInterruptEnable** IP command trigger during AHB access error.

kQSPI\_IPCommandTriggerDuringIPAccessInterruptEnable IP command trigger cannot be executed.

**kQSPI\_IPCommandTriggerDuringAHBGrantInterruptEnable** IP command trigger during AHB grant error.

**kQSPI\_IPCommandTransactionFinishedInterruptEnable** IP command transaction finished interrupt enable.

kQSPI\_AllInterruptEnable All error interrupt enable.

### 13.4.9 enum \_qspi\_dma\_enable

#### Enumerator

kQSPI\_RxBufferDrainDMAEnable Rx buffer drain DMA.

### 13.4.10 enum qspi\_dqs\_phrase\_shift\_t

#### Enumerator

kQSPI\_DQSNoPhraseShift No phase shift.
 kQSPI\_DQSPhraseShift45Degree Select 45 degree phase shift.
 kQSPI\_DQSPhraseShift90Degree Select 90 degree phase shift.
 kQSPI\_DQSPhraseShift135Degree Select 135 degree phase shift.

#### 13.5 Function Documentation

### 13.5.1 uint32\_t QSPI\_GetInstance ( QuadSPI\_Type \* base )

#### **Parameters**

| base | QSPI base pointer. |
|------|--------------------|
|------|--------------------|

## 13.5.2 void QSPI\_Init ( QuadSPI\_Type \* base, qspi\_config\_t \* config, uint32\_t srcClock\_Hz )

This function enables the clock for QSPI and also configures the QSPI with the input configure parameters. Users should call this function before any QSPI operations.

#### **Parameters**

| base        | Pointer to QuadSPI Type.           |
|-------------|------------------------------------|
| config      | QSPI configure structure.          |
| srcClock_Hz | QSPI source clock frequency in Hz. |

### 13.5.3 void QSPI\_GetDefaultQspiConfig ( qspi\_config\_t \* config )

#### **Parameters**

| config | QSPI configuration structure. |
|--------|-------------------------------|
|--------|-------------------------------|

### 13.5.4 void QSPI Deinit ( QuadSPI Type \* base )

Clears the QSPI state and QSPI module registers.

#### **Parameters**

| base | Pointer to QuadSPI Type. |
|------|--------------------------|
|------|--------------------------|

## 13.5.5 void QSPI\_SetFlashConfig ( QuadSPI\_Type \* base, qspi\_flash\_config\_t \* config )

This function configures the serial flash relevant parameters, such as the size, command, and so on. The flash configuration value cannot have a default value. The user needs to configure it according to the QSPI features.

#### **Parameters**

| base   | Pointer to QuadSPI Type.        |
|--------|---------------------------------|
| config | Flash configuration parameters. |

### 13.5.6 void QSPI\_SoftwareReset ( QuadSPI\_Type \* base )

This function sets the software reset flags for both AHB and buffer domain and resets both AHB buffer and also IP FIFOs.

#### **Parameters**

| base | Pointer to QuadSPI Type. |
|------|--------------------------|
|------|--------------------------|

### 13.5.7 static void QSPI\_Enable ( QuadSPI\_Type \* base, bool enable ) [inline], [static]

### MCUXpresso SDK API Reference Manual

207

#### **Parameters**

| base   | Pointer to QuadSPI Type.                     |
|--------|----------------------------------------------|
| enable | True means enable QSPI, false means disable. |

### 13.5.8 static uint32\_t QSPI\_GetStatusFlags ( QuadSPI\_Type \* base ) [inline], [static]

#### **Parameters**

| base | Pointer to QuadSPI Type. |
|------|--------------------------|
|------|--------------------------|

#### Returns

status flag, use status flag to AND \_qspi\_flags could get the related status.

## 13.5.9 static uint32\_t QSPI\_GetErrorStatusFlags ( QuadSPI\_Type \* base ) [inline], [static]

#### **Parameters**

| base | Pointer to QuadSPI Type. |
|------|--------------------------|
|------|--------------------------|

#### Returns

status flag, use status flag to AND \_qspi\_error\_flags could get the related status.

## 13.5.10 static void QSPI\_ClearErrorFlag ( QuadSPI\_Type \* base, uint32\_t mask ) [inline], [static]

#### Parameters

| base | Pointer to QuadSPI Type. |
|------|--------------------------|
|------|--------------------------|

| mask | Which kind of QSPI flags to be cleared, a combination of _qspi_error_flags. |
|------|-----------------------------------------------------------------------------|
|------|-----------------------------------------------------------------------------|

## 13.5.11 static void QSPI\_EnableInterrupts ( QuadSPI\_Type \* base, uint32\_t mask ) [inline], [static]

#### **Parameters**

| base | Pointer to QuadSPI Type. |
|------|--------------------------|
| mask | QSPI interrupt source.   |

## 13.5.12 static void QSPI\_DisableInterrupts ( QuadSPI\_Type \* base, uint32\_t mask ) [inline], [static]

#### **Parameters**

| base | Pointer to QuadSPI Type. |
|------|--------------------------|
| mask | QSPI interrupt source.   |

## 13.5.13 static void QSPI\_EnableDMA ( QuadSPI\_Type \* base, uint32\_t mask, bool enable ) [inline], [static]

#### **Parameters**

| base   | Pointer to QuadSPI Type.                    |
|--------|---------------------------------------------|
| mask   | QSPI DMA source.                            |
| enable | True means enable DMA, false means disable. |

## 13.5.14 static uint32\_t QSPI\_GetTxDataRegisterAddress ( QuadSPI\_Type \* base ) [inline], [static]

It is used for DMA operation.

#### **Parameters**

| base | Pointer to QuadSPI Type. |
|------|--------------------------|
|------|--------------------------|

#### Returns

QSPI Tx data register address.

### 13.5.15 uint32\_t QSPI\_GetRxDataRegisterAddress ( QuadSPI\_Type \* base )

This function returns the Rx data register address or Rx buffer address according to the Rx read area settings.

#### **Parameters**

| base | Pointer to QuadSPI Type. |
|------|--------------------------|
|------|--------------------------|

#### Returns

QSPI Rx data register address.

## 13.5.16 static void QSPI\_SetIPCommandAddress ( QuadSPI\_Type \* base, uint32\_t addr ) [inline], [static]

#### **Parameters**

| base | Pointer to QuadSPI Type. |
|------|--------------------------|
| addr | IP command address.      |

## 13.5.17 static void QSPI\_SetIPCommandSize ( QuadSPI\_Type \* base, uint32\_t size ) [inline], [static]

MCUXpresso SDK API Reference Manual

| base | Pointer to QuadSPI Type. |
|------|--------------------------|
| size | IP command size.         |

### 13.5.18 void QSPI\_ExecuteIPCommand ( QuadSPI\_Type \* base, uint32\_t index )

#### **Parameters**

| base  | Pointer to QuadSPI Type.                     |
|-------|----------------------------------------------|
| index | IP command located in which LUT table index. |

## 13.5.19 void QSPI\_ExecuteAHBCommand ( QuadSPI\_Type \* base, uint32\_t index )

#### **Parameters**

| base  | Pointer to QuadSPI Type.                      |
|-------|-----------------------------------------------|
| index | AHB command located in which LUT table index. |

## 13.5.20 static void QSPI\_EnableIPParallelMode ( QuadSPI\_Type \* base, bool enable ) [inline], [static]

#### Parameters

| base   | Pointer to QuadSPI Type.                                            |
|--------|---------------------------------------------------------------------|
| enable | True means enable parallel mode, false means disable parallel mode. |

## 13.5.21 static void QSPI\_EnableAHBParallelMode ( QuadSPI\_Type \* base, bool enable ) [inline], [static]

211

| base   | Pointer to QuadSPI Type.                                            |
|--------|---------------------------------------------------------------------|
| enable | True means enable parallel mode, false means disable parallel mode. |

## 13.5.22 void QSPI\_UpdateLUT ( QuadSPI\_Type \* base, uint32\_t index, uint32\_t \* cmd )

#### **Parameters**

| base  | Pointer to QuadSPI Type.                                                   |
|-------|----------------------------------------------------------------------------|
| index | Which LUT index needs to be located. It should be an integer divided by 4. |
| cmd   | Command sequence array.                                                    |

## 13.5.23 static void QSPI\_ClearFifo ( QuadSPI\_Type \* base, uint32\_t mask ) [inline], [static]

#### **Parameters**

| base | Pointer to QuadSPI Type.               |
|------|----------------------------------------|
| mask | Which kind of QSPI FIFO to be cleared. |

## 13.5.24 static void QSPI\_ClearCommandSequence ( QuadSPI\_Type \* base, qspi\_command\_seq\_t seq ) [inline], [static]

This function can reset the command sequence.

#### **Parameters**

| base | QSPI base address.                                                        |
|------|---------------------------------------------------------------------------|
| seq  | Which command sequence need to reset, IP command, buffer command or both. |

## 13.5.25 static void QSPI\_EnableDDRMode ( QuadSPI\_Type \* base, bool enable ) [inline], [static]

**MCUXpresso SDK API Reference Manual** 

#### **Parameters**

| base   | QSPI base pointer                                         |
|--------|-----------------------------------------------------------|
| eanble | True means enable DDR mode, false means disable DDR mode. |

## 13.5.26 void QSPI\_SetReadDataArea ( QuadSPI\_Type \* base, qspi\_read\_area\_t area )

This function can set the RX buffer readout, from AHB bus or IP Bus.

#### **Parameters**

| base | QSPI base address.                                            |
|------|---------------------------------------------------------------|
| area | QSPI Rx buffer readout area. AHB bus buffer or IP bus buffer. |

## 13.5.27 void QSPI\_WriteBlocking ( QuadSPI\_Type \* base, uint32\_t \* buffer, size\_t size )

Note

This function blocks via polling until all bytes have been sent.

#### **Parameters**

| base   | QSPI base pointer                |
|--------|----------------------------------|
| buffer | The data bytes to send           |
| size   | The number of data bytes to send |

## 13.5.28 static void QSPI\_WriteData ( QuadSPI\_Type \* base, uint32\_t data ) [inline], [static]

Parameters

213

| base | QSPI base pointer      |
|------|------------------------|
| data | The data bytes to send |

## 13.5.29 void QSPI\_ReadBlocking ( QuadSPI\_Type \* base, uint32\_t \* buffer, size\_t size )

#### Note

This function blocks via polling until all bytes have been sent. Users shall notice that this receive size shall not bigger than 64 bytes. As this interface is used to read flash status registers. For flash contents read, please use AHB bus read, this is much more efficiency.

#### **Parameters**

| base   | QSPI base pointer                   |
|--------|-------------------------------------|
| buffer | The data bytes to send              |
| size   | The number of data bytes to receive |

### 13.5.30 uint32\_t QSPI\_ReadData ( QuadSPI\_Type \* base )

#### **Parameters**

| base | QSPI base pointer |
|------|-------------------|
|      |                   |

#### Returns

The data in the FIFO.

## 13.5.31 static void QSPI\_TransferSendBlocking ( QuadSPI\_Type \* base, qspi\_transfer\_t \* xfer ) [inline], [static]

This function writes a continuous data to the QSPI transmit FIFO. This function is a block function and can return only when finished. This function uses polling methods.

#### **Parameters**

| base | Pointer to QuadSPI Type. |
|------|--------------------------|
| xfer | QSPI transfer structure. |

## 13.5.32 static void QSPI\_TransferReceiveBlocking ( QuadSPI\_Type \* base, qspi\_transfer\_t \* xfer ) [inline], [static]

This function reads continuous data from the QSPI receive buffer/FIFO. This function is a blocking function and can return only when finished. This function uses polling methods. Users shall notice that this receive size shall not bigger than 64 bytes. As this interface is used to read flash status registers. For flash contents read, please use AHB bus read, this is much more efficiency.

#### **Parameters**

| base | Pointer to QuadSPI Type. |
|------|--------------------------|
| xfer | QSPI transfer structure. |

### Chapter 14

### **RDC: Resource Domain Controller**

#### 14.1 Overview

The MCUXpresso SDK provides a driver for the RDC module of MCUXpresso SDK devices.

The Resource Domain Controller (RDC) provides robust support for the isolation of destination memory mapped locations such as peripherals and memory to a single core, a bus master, or set of cores and bus masters.

The RDC driver should be used together with the RDC\_SEMA42 driver.

#### **Data Structures**

```
    struct rdc_hardware_config_t
        RDC hardware configuration. More...
    struct rdc_domain_assignment_t
        Master domain assignment. More...
    struct rdc_periph_access_config_t
        Peripheral domain access permission configuration. More...
    struct rdc_mem_access_config_t
        Memory region domain access control configuration. More...
    struct rdc_mem_status_t
        Memory region access violation status. More...
```

#### **Macros**

```
• #define FSL_RDC_DRIVER_VERSION (MAKE_VERSION(2, 0, 0)) 
Version 2.0.0.
```

#### **Enumerations**

```
enum _rdc_interrupts { kRDC_RestoreCompleteInterrupt = RDC_INTCTRL_RCI_EN_MASK } RDC interrupts.
enum _rdc_flags { kRDC_PowerDownDomainOn = RDC_STAT_PDS_MASK } RDC status.
enum _rdc_access_policy { kRDC_NoAccess = 0, kRDC_WriteOnly = 1, kRDC_ReadOnly = 2, kRDC_ReadWrite = 3 } Access permission policy.
```

#### **Functions**

• void RDC\_Init (RDC\_Type \*base)

#### Overview

Initializes the RDC module.

• void RDC\_Deinit (RDC\_Type \*base)

De-initializes the RDC module.

• static void RDC\_GetHardwareConfig (RDC\_Type \*base, rdc\_hardware\_config\_t \*config)

Gets the RDC hardware configuration.

- static void RDC\_EnableInterrupts (RDC\_Type \*base, uint32\_t mask) Enable interrupts.
- static void RDC\_DisableInterrupts (RDC\_Type \*base, uint32\_t mask)

Disable interrupts.

• static uint32\_t RDC\_GetInterruptStatus (RDC\_Type \*base)

Get the interrupt pending status.

• static void RDC\_ClearInterruptStatus (RDC\_Type \*base, uint32\_t mask)

Clear interrupt pending status.

• static uint32\_t RDC\_GetStatus (RDC\_Type \*base)

Get RDC status.

• static void RDC\_ClearStatus (RDC\_Type \*base, uint32\_t mask)

Clear RDC status.

• static void RDC\_SetMasterDomainAssignment (RDC\_Type \*base, rdc\_master\_t master, const rdc\_domain\_assignment\_t \*assignment)

Set master domain assignment.

- static void RDC\_GetDefaultMasterDomainAssignment (rdc\_domain\_assignment\_t \*assignment)

  Get default master domain assignment.
- static void RDC\_LockMasterDomainAssignment (RDC\_Type \*base, rdc\_master\_t master)

  Lock master domain assignment.
- void RDC\_SetPeriphAccessConfig (RDC\_Type \*base, const rdc\_periph\_access\_config\_t \*config)

  Set peripheral access policy.
- void RDC\_GetDefaultPeriphAccessConfig (rdc\_periph\_access\_config\_t \*config)

Get default peripheral access policy.

• static void RDC\_LockPeriphAccessConfig (RDC\_Type \*base, rdc\_periph\_t periph)

Lock peripheral access policy configuration.

- void RDC\_SetMemAccessConfig (RDC\_Type \*base, const rdc\_mem\_access\_config\_t \*config)

  Set memory region access policy.
- void RDC GetDefaultMemAccessConfig (rdc mem access config t \*config)

Get default memory region access policy.

static void RDC\_LockMemAccessConfig (RDC\_Type \*base, rdc\_mem\_t mem)

Lock memory access policy configuration.

- static void RDC\_SetMemAccess Valid (RDC\_Type \*base, rdc\_mem\_t mem, bool valid)
- Enable or disable memory access policy configuration.

   void RDC\_GetMemViolationStatus (RDC\_Type \*base, rdc\_mem\_t mem, rdc\_mem\_status\_t

Get the memory region violation status.

\*status)

• static void RDC ClearMemViolationFlag (RDC Type \*base, rdc mem t mem)

Clear the memory region violation flag.

• static uint8\_t RDC\_GetCurrentMasterDomainId (RDC\_Type \*base)

Gets the domain ID of the current bus master.

217

#### 14.2 Data Structure Documentation

### 14.2.1 struct rdc\_hardware\_config\_t

#### **Data Fields**

- uint32\_t domainNumber: 4
  - Number of domains.
- uint32\_t masterNumber: 8
  - Number of bus masters.
- uint32\_t periphNumber: 8
  - *Number of peripherals.*
- uint32\_t memNumber: 8

Number of memory regions.

#### 14.2.1.0.0.12 Field Documentation

- 14.2.1.0.0.12.1 uint32\_t rdc\_hardware\_config\_t::domainNumber
- 14.2.1.0.0.12.2 uint32\_t rdc\_hardware\_config\_t::masterNumber
- 14.2.1.0.0.12.3 uint32\_t rdc\_hardware\_config\_t::periphNumber
- 14.2.1.0.0.12.4 uint32 t rdc hardware config t::memNumber

#### 14.2.2 struct rdc\_domain\_assignment\_t

#### **Data Fields**

- uint32\_t domainId: 2U
  - Domain ID.
- uint32\_t \_\_pad0\_\_: 29U
  - Reserved.
- uint32\_t lock: 1U

Lock the domain assignment.

#### 14.2.2.0.0.13 Field Documentation

- 14.2.2.0.0.13.1 uint32\_t rdc\_domain\_assignment\_t::domainId
- 14.2.2.0.0.13.2 uint32 t rdc domain assignment t:: pad0
- 14.2.2.0.0.13.3 uint32 t rdc domain assignment t::lock
- 14.2.3 struct rdc periph access config t

#### **Data Fields**

rdc\_periph\_t periph

#### **Data Structure Documentation**

Peripheral name.

bool lock

Lock the permission until reset.

bool enableSema

Enable semaphore or not, when enabled, master should call RDC\_SEMA42\_Lock to lock the semaphore gate accordingly before access the peripheral.

• uint16\_t policy Access policy.

#### 14.2.3.0.0.14 Field Documentation

```
14.2.3.0.0.14.1 rdc_periph_t rdc_periph_access_config_t::periph
```

14.2.3.0.0.14.2 bool rdc\_periph\_access\_config\_t::lock

14.2.3.0.0.14.3 bool rdc\_periph\_access\_config\_t::enableSema

14.2.3.0.0.14.4 uint16\_t rdc\_periph\_access\_config\_t::policy

### 14.2.4 struct rdc\_mem\_access\_config\_t

Note that when setting the baseAddress and endAddress, should be aligned to the region resolution, see rdc\_mem\_t definitions.

#### **Data Fields**

• rdc\_mem\_t mem

Memory region descriptor name.

bool lock

Lock the configuration.

• uint32\_t baseAddress

Start address of the memory region.

• uint32\_t endAddress

End address of the memory region.

uint16\_t policy

Access policy.

219

#### 14.2.4.0.0.15 Field Documentation

14.2.4.0.0.15.1 rdc\_mem\_t rdc\_mem\_access\_config\_t::mem

14.2.4.0.0.15.2 bool rdc\_mem\_access\_config\_t::lock

14.2.4.0.0.15.3 uint32\_t rdc\_mem\_access\_config\_t::baseAddress

14.2.4.0.0.15.4 uint32\_t rdc\_mem\_access\_config\_t::endAddress

14.2.4.0.0.15.5 uint16\_t rdc\_mem\_access\_config\_t::policy

14.2.5 struct rdc\_mem\_status\_t

#### **Data Fields**

bool has Violation

Violating happens or not.

• uint8 t domainID

Violating Domain ID.

• uint32\_t address

Violating Address.

#### 14.2.5.0.0.16 Field Documentation

14.2.5.0.0.16.1 bool rdc\_mem\_status\_t::hasViolation

14.2.5.0.0.16.2 uint8 t rdc mem status t::domainID

14.2.5.0.0.16.3 uint32 t rdc mem status t::address

### 14.3 Macro Definition Documentation

14.3.1 #define FSL RDC DRIVER VERSION (MAKE VERSION(2, 0, 0))

#### 14.4 Enumeration Type Documentation

#### 14.4.1 enum \_rdc\_interrupts

#### Enumerator

**kRDC\_RestoreCompleteInterrupt** Interrupt generated when the RDC has completed restoring state to a recently re-powered memory regions.

### 14.4.2 enum rdc\_flags

Enumerator

**kRDC\_PowerDownDomainOn** Power down domain is ON.

### 14.4.3 enum \_rdc\_access\_policy

Enumerator

kRDC NoAccess Could not read or write.

*kRDC\_WriteOnly* Write only.

kRDC\_ReadOnly Read only.

kRDC\_ReadWrite Read and write.

#### 14.5 Function Documentation

### 14.5.1 void RDC\_Init ( RDC\_Type \* base )

This function enables the RDC clock.

**Parameters** 

base RDC peripheral base address.

### 14.5.2 void RDC\_Deinit ( RDC\_Type \* base )

This function disables the RDC clock.

**Parameters** 

base RDC peripheral base address.

## 14.5.3 static void RDC\_GetHardwareConfig ( RDC\_Type \* base, rdc\_hardware\_config\_t \* config ) [inline], [static]

This function gets the RDC hardware configurations, including number of bus masters, number of domains, number of memory regions and number of peripherals.

221

#### **Parameters**

| base   | RDC peripheral base address.                       |
|--------|----------------------------------------------------|
| config | Pointer to the structure to get the configuration. |

## 14.5.4 static void RDC\_EnableInterrupts ( RDC\_Type \* base, uint32\_t mask ) [inline], [static]

#### **Parameters**

| base | RDC peripheral base address.                                     |
|------|------------------------------------------------------------------|
| mask | Interrupts to enable, it is OR'ed value of enum _rdc_interrupts. |

## 14.5.5 static void RDC\_DisableInterrupts ( RDC\_Type \* base, uint32\_t mask ) [inline], [static]

#### **Parameters**

| base | RDC peripheral base address.                                      |
|------|-------------------------------------------------------------------|
| mask | Interrupts to disable, it is OR'ed value of enum _rdc_interrupts. |

## 14.5.6 static uint32\_t RDC\_GetInterruptStatus ( RDC\_Type \* base ) [inline], [static]

#### **Parameters**

| base | RDC peripheral base address. |
|------|------------------------------|
|------|------------------------------|

#### Returns

Interrupts pending status, it is OR'ed value of enum <u>\_rdc\_interrupts</u>.

## 14.5.7 static void RDC\_ClearInterruptStatus ( RDC\_Type \* base, uint32\_t mask ) [inline], [static]

#### **Parameters**

| base | RDC peripheral base address.                                |
|------|-------------------------------------------------------------|
| mask | Status to clear, it is OR'ed value of enum _rdc_interrupts. |

## 14.5.8 static uint32\_t RDC\_GetStatus ( RDC\_Type \* base ) [inline], [static]

#### Parameters

| base | RDC peripheral base address. |
|------|------------------------------|
|------|------------------------------|

#### Returns

mask RDC status, it is OR'ed value of enum \_rdc\_flags.

## 14.5.9 static void RDC\_ClearStatus ( RDC\_Type \* base, uint32\_t mask ) [inline], [static]

#### Parameters

| base | RDC peripheral base address.                               |
|------|------------------------------------------------------------|
| mask | RDC status to clear, it is OR'ed value of enum _rdc_flags. |

# 14.5.10 static void RDC\_SetMasterDomainAssignment ( RDC\_Type \* base, rdc\_master\_t master, const rdc\_domain\_assignment\_t \* assignment ) [inline], [static]

#### **Parameters**

| base   | RDC peripheral base address. |
|--------|------------------------------|
| master | Which master to set.         |

| assignment | Pointer to the assignment. |
|------------|----------------------------|
|------------|----------------------------|

## 14.5.11 static void RDC\_GetDefaultMasterDomainAssignment ( rdc\_domain\_assignment\_t \* assignment ) [inline], [static]

The default configuration is:

```
assignment->domainId = 0U;
assignment->lock = 0U;
```

#### **Parameters**

| assignment   Pointer to the assignment. |
|-----------------------------------------|
|-----------------------------------------|

## 14.5.12 static void RDC\_LockMasterDomainAssignment ( RDC\_Type \* base, rdc master t master ) [inline], [static]

Once locked, it could not be unlocked until next reset.

#### **Parameters**

| base   | RDC peripheral base address. |
|--------|------------------------------|
| master | Which master to lock.        |

## 14.5.13 void RDC\_SetPeriphAccessConfig ( RDC\_Type \* base, const rdc\_periph\_access\_config\_t \* config )

#### **Parameters**

| base   | RDC peripheral base address.         |
|--------|--------------------------------------|
| config | Pointer to the policy configuration. |

## 14.5.14 void RDC\_GetDefaultPeriphAccessConfig ( rdc\_periph\_access\_config\_t \* config )

The default configuration is:

### MCUXpresso SDK API Reference Manual

#### **Parameters**

| config | Pointer to the policy configuration. |
|--------|--------------------------------------|
|--------|--------------------------------------|

## 14.5.15 static void RDC\_LockPeriphAccessConfig ( RDC\_Type \* base, rdc periph t periph ) [inline], [static]

Once locked, it could not be unlocked until reset.

#### **Parameters**

| base                             | RDC peripheral base address. |  |
|----------------------------------|------------------------------|--|
| periph Which peripheral to lock. |                              |  |

## 14.5.16 void RDC\_SetMemAccessConfig ( RDC\_Type \* base, const rdc\_mem\_access\_config\_t \* config )

Note that when setting the baseAddress and endAddress in config, should be aligned to the region resolution, see rdc\_mem\_t definitions.

#### **Parameters**

| base   | RDC peripheral base address.         |
|--------|--------------------------------------|
| config | Pointer to the policy configuration. |

## 14.5.17 void RDC\_GetDefaultMemAccessConfig ( rdc\_mem\_access\_config\_t \* config )

The default configuration is:

#### MCUXpresso SDK API Reference Manual

#### **Parameters**

| config | Pointer to the policy configuration. |
|--------|--------------------------------------|
|--------|--------------------------------------|

## 14.5.18 static void RDC\_LockMemAccessConfig ( RDC\_Type \* base, rdc\_mem\_t mem ) [inline], [static]

Once locked, it could not be unlocked until reset. After locked, you can only call RDC\_SetMemAccess-Valid to enable the configuration, but can not disable it or change other settings.

#### **Parameters**

| base | RDC peripheral base address. |
|------|------------------------------|
| mem  | Which memory region to lock. |

## 14.5.19 static void RDC\_SetMemAccessValid ( RDC\_Type \* base, rdc\_mem\_t mem, bool valid ) [inline], [static]

#### **Parameters**

| base  | base RDC peripheral base address.        |  |
|-------|------------------------------------------|--|
| mem   | Which memory region to operate.          |  |
| valid | Pass in true to valid, false to invalid. |  |

## 14.5.20 void RDC\_GetMemViolationStatus ( RDC\_Type \* base, rdc\_mem\_t mem, rdc\_mem\_status\_t \* status\_)

The first access violation is captured. Subsequent violations are ignored until the status register is cleared. Contents are cleared upon reading the register. Clearing of contents occurs only when the status is read by the memory region's associated domain ID(s).

#### **Parameters**

| base RDC peripheral base | nddress. |
|--------------------------|----------|
|--------------------------|----------|

| mem                         | Which memory region to get. |
|-----------------------------|-----------------------------|
| status The returned status. |                             |

## 14.5.21 static void RDC\_ClearMemViolationFlag ( RDC\_Type \* base, rdc\_mem\_t mem ) [inline], [static]

#### **Parameters**

| base | RDC peripheral base address.  |
|------|-------------------------------|
| mem  | Which memory region to clear. |

## 14.5.22 static uint8\_t RDC\_GetCurrentMasterDomainId ( RDC\_Type \* base ) [inline], [static]

This function returns the domain ID of the current bus master.

#### **Parameters**

| base | RDC peripheral base address. |
|------|------------------------------|
|------|------------------------------|

#### Returns

Domain ID of current bus master.

## Chapter 15 RDC SEMA42: Hardware Semaphores Driver

#### 15.1 Overview

The MCUXpresso SDK provides a driver for the RDC\_SEMA42 module of MCUXpresso SDK devices.

The RDC\_SEMA42 driver should be used together with RDC driver.

Before using the RDC\_SEMA42, call the RDC\_SEMA42\_Init() function to initialize the module. Note that this function only enables the clock but does not reset the gates because the module might be used by other processors at the same time. To reset the gates, call either the RDC\_SEMA42\_ResetGate() or RDC\_SEMA42\_ResetAllGates() functions. The function RDC\_SEMA42\_Deinit() deinitializes the RD-C\_SEMA42.

The RDC\_SEMA42 provides two functions to lock the RDC\_SEMA42 gate. The function RDC\_SEMA42\_TryLock() tries to lock the gate. If the gate has been locked by another processor, this function returns an error immediately. The function RDC\_SEMA42\_Lock() is a blocking method, which waits until the gate is free and locks it.

The RDC\_SEMA42\_Unlock() unlocks the RDC\_SEMA42 gate. The gate can only be unlocked by the processor which locked it. If the gate is not locked by the current processor, this function takes no effect. The function RDC\_SEMA42\_GetGateStatus() returns a status whether the gate is unlocked and which processor locks the gate. The function RDC\_SEMA42\_GetLockDomainID() returns the ID of the domain which has locked the gate.

The RDC\_SEMA42 gate can be reset to unlock forcefully. The function RDC\_SEMA42\_ResetGate() resets a specific gate. The function RDC\_SEMA42\_ResetAllGates() resets all gates.

#### **Macros**

- #define RDC SEMA42 GATE NUM RESET ALL (64U)
  - The number to reset all RDC\_SEMA42 gates.
- #define RDC\_SEMA42\_GATEn(base, n) (\*(&((base)->GATE0) + (n)))
  - RDC SEMA42 gate n register address.
- #define RDC\_SEMA42\_GATE\_COUNT (64U)
  - RDC\_SEMA42 gate count.

#### **Functions**

- void RDC SEMA42 Init (RDC SEMAPHORE Type \*base)
  - *Initializes the RDC\_SEMA42 module.*
- void RDC\_SEMA42\_Deinit (RDC\_SEMAPHORE\_Type \*base)
  - De-initializes the RDC SEMA42 module.
- status\_t RDC\_SEMA42\_TryLock (RDC\_SEMAPHORE\_Type \*base, uint8\_t gateNum, uint8\_t masterIndex, uint8\_t domainId)

*Tries to lock the RDC\_SEMA42 gate.* 

- void RDC\_SEMA42\_Lock (RDC\_SEMAPHORE\_Type \*base, uint8\_t gateNum, uint8\_t master-Index, uint8\_t domainId)
  - Locks the RDC\_SEMA42 gate.
- static void RDC\_SEMA42\_Unlock (RDC\_SEMAPHORE\_Type \*base, uint8\_t gateNum) Unlocks the RDC\_SEMA42 gate.
- static int32\_t RDC\_SEMA42\_GetLockMasterIndex (RDC\_SEMAPHORE\_Type \*base, uint8\_t gateNum)
  - Gets which master has currently locked the gate.
- int32\_t RDC\_SEMA42\_GetLockDomainID (RDC\_SEMAPHORE\_Type \*base, uint8\_t gateNum) Gets which domain has currently locked the gate.
- status\_t RDC\_SEMA42\_ResetGate (RDC\_SEMAPHORE\_Type \*base, uint8\_t gateNum)

  Resets the RDC\_SEMA42 gate to an unlocked status.
- static status\_t RDC\_SEMA42\_ResetAllGates (RDC\_SEMAPHORE\_Type \*base) Resets all RDC\_SEMA42 gates to an unlocked status.

#### **Driver version**

- #define FSL\_RDC\_SEMA42\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 0)) RDC\_SEMA42 driver version.
- 15.2 Macro Definition Documentation
- 15.2.1 #define RDC\_SEMA42\_GATE\_NUM\_RESET\_ALL (64U)
- 15.2.2 #define RDC\_SEMA42\_GATEn( base, n) (\*(&((base)->GATE0) + (n)))
- 15.2.3 #define RDC SEMA42 GATE COUNT (64U)
- 15.3 Function Documentation
- 15.3.1 void RDC SEMA42 Init ( RDC SEMAPHORE Type \* base )

This function initializes the RDC\_SEMA42 module. It only enables the clock but does not reset the gates because the module might be used by other processors at the same time. To reset the gates, call either RDC\_SEMA42\_ResetGate or RDC\_SEMA42\_ResetAllGates function.

**Parameters** 

base RDC\_SEMA42 peripheral base address.

### 15.3.2 void RDC SEMA42 Deinit ( RDC SEMAPHORE Type \* base )

This function de-initializes the RDC\_SEMA42 module. It only disables the clock.

#### **Parameters**

| base | RDC_SEMA42 peripheral base address. |
|------|-------------------------------------|
|------|-------------------------------------|

## 15.3.3 status\_t RDC\_SEMA42\_TryLock ( RDC\_SEMAPHORE\_Type \* base, uint8\_t gateNum, uint8\_t masterIndex, uint8\_t domainId )

This function tries to lock the specific RDC\_SEMA42 gate. If the gate has been locked by another processor, this function returns an error code.

#### **Parameters**

| base        | RDC_SEMA42 peripheral base address. |  |
|-------------|-------------------------------------|--|
| gateNum     | Gate number to lock.                |  |
| masterIndex | Current processor master index.     |  |
| domainId    | Current processor domain ID.        |  |

#### Return values

| kStatus_Success | Lock the sema42 gate successfully.                |
|-----------------|---------------------------------------------------|
| kStatus_Failed  | Sema42 gate has been locked by another processor. |

## 15.3.4 void RDC\_SEMA42\_Lock ( RDC\_SEMAPHORE\_Type \* base, uint8\_t gateNum, uint8\_t masterIndex, uint8\_t domainId )

This function locks the specific RDC\_SEMA42 gate. If the gate has been locked by other processors, this function waits until it is unlocked and then lock it.

#### **Parameters**

| base        | RDC_SEMA42 peripheral base address. |  |
|-------------|-------------------------------------|--|
| gateNum     | Gate number to lock.                |  |
| masterIndex | Current processor master index.     |  |
| domainId    | Current processor domain ID.        |  |

## 15.3.5 static void RDC\_SEMA42\_Unlock ( RDC\_SEMAPHORE\_Type \* base, uint8\_t gateNum ) [inline], [static]

This function unlocks the specific RDC\_SEMA42 gate. It only writes unlock value to the RDC\_SEMA42 gate register. However, it does not check whether the RDC\_SEMA42 gate is locked by the current processor or not. As a result, if the RDC\_SEMA42 gate is not locked by the current processor, this function has no effect.

#### **Parameters**

| base    | RDC_SEMA42 peripheral base address. |
|---------|-------------------------------------|
| gateNum | Gate number to unlock.              |

## 15.3.6 static int32\_t RDC\_SEMA42\_GetLockMasterIndex ( RDC\_SEMAPHORE\_Type \* base, uint8 t gateNum ) [inline], [static]

#### **Parameters**

| base    | RDC_SEMA42 peripheral base address. |
|---------|-------------------------------------|
| gateNum | Gate number.                        |

#### Returns

Return -1 if the gate is not locked by any master, otherwise return the master index.

## 15.3.7 int32\_t RDC\_SEMA42\_GetLockDomainID ( RDC\_SEMAPHORE\_Type \* base, uint8\_t gateNum )

#### **Parameters**

| base    | RDC_SEMA42 peripheral base address. |
|---------|-------------------------------------|
| gateNum | Gate number.                        |

#### Returns

Return -1 if the gate is not locked by any domain, otherwise return the domain ID.

## 15.3.8 status\_t RDC\_SEMA42\_ResetGate ( RDC\_SEMAPHORE\_Type \* base, uint8 t gateNum )

This function resets a RDC\_SEMA42 gate to an unlocked status.

MCUXpresso SDK API Reference Manual

#### Parameters

| base    | RDC_SEMA42 peripheral base address. |
|---------|-------------------------------------|
| gateNum | Gate number.                        |

#### Return values

| kStatus_Success | RDC_SEMA42 gate is reset successfully. |
|-----------------|----------------------------------------|
| kStatus_Failed  | Some other reset process is ongoing.   |

## 15.3.9 static status\_t RDC\_SEMA42\_ResetAllGates ( RDC\_SEMAPHORE\_Type \* base ) [inline], [static]

This function resets all RDC\_SEMA42 gate to an unlocked status.

#### Parameters

| base | RDC_SEMA42 peripheral base address. |
|------|-------------------------------------|
|------|-------------------------------------|

#### Return values

| kStatus_Success                | RDC_SEMA42 is reset successfully.    |
|--------------------------------|--------------------------------------|
| kStatus_RDC_SEMA42<br>Reseting | Some other reset process is ongoing. |

### Chapter 16

### **SAI: Serial Audio Interface**

#### 16.1 Overview

The MCUXpresso SDK provides a peripheral driver for the Serial Audio Interface (SAI) module of MC-UXpresso SDK devices.

SAI driver includes functional APIs and transactional APIs.

Functional APIs target low-level APIs. Functional APIs can be used for SAI initialization, configuration and operation, and for optimization and customization purposes. Using the functional API requires the knowledge of the SAI peripheral and how to organize functional APIs to meet the application requirements. All functional API use the peripheral base address as the first parameter. SAI functional operation groups provide the functional API set.

Transactional APIs target high-level APIs. Transactional APIs can be used to enable the peripheral and in the application if the code size and performance of transactional APIs satisfy the requirements. If the code size and performance are a critical requirement, see the transactional API implementation and write a custom code. All transactional APIs use the sai\_handle\_t as the first parameter. Initialize the handle by calling the SAI\_TransferTxCreateHandle() or SAI\_TransferRxCreateHandle() API.

Transactional APIs support asynchronous transfer. This means that the functions SAI\_TransferSendNon-Blocking() and SAI\_TransferReceiveNonBlocking() set up the interrupt for data transfer. When the transfer completes, the upper layer is notified through a callback function with the kStatus\_SAI\_TxIdle and kStatus\_SAI\_RxIdle status.

### 16.2 Typical use case

### 16.2.1 SAI Send/receive using an interrupt method

Refer to the driver examples codes located at <SDK\_ROOT>/boards/<BOARD>/driver\_examples/sai

### 16.2.2 SAI Send/receive using a DMA method

Refer to the driver examples codes located at <SDK\_ROOT>/boards/<BOARD>/driver\_examples/sai

#### **Modules**

- SAI DMA Driver
- SAI EDMA Driver
- SAI SDMA Driver

#### Typical use case

#### **Data Structures**

```
    struct sai_config_t
        SAI user configuration structure. More...
    struct sai_transfer_format_t
        sai transfer format More...
    struct sai_transfer_t
        SAI transfer structure. More...
    struct sai_handle_t
        SAI handle structure. More...
```

#### **Macros**

• #define SAI\_XFER\_QUEUE\_SIZE (4)

SAI transfer queue size, user can refine it according to use case.

### **Typedefs**

• typedef void(\* sai\_transfer\_callback\_t)(I2S\_Type \*base, sai\_handle\_t \*handle, status\_t status, void \*userData)

SAI transfer callback prototype.

#### **Enumerations**

```
• enum sai status t {
 kStatus_SAI_TxBusy = MAKE_STATUS(kStatusGroup_SAI, 0),
 kStatus_SAI_RxBusy = MAKE_STATUS(kStatusGroup_SAI, 1),
 kStatus_SAI_TxError = MAKE_STATUS(kStatusGroup_SAI, 2),
 kStatus_SAI_RxError = MAKE_STATUS(kStatusGroup_SAI, 3),
 kStatus SAI QueueFull = MAKE STATUS(kStatusGroup SAI, 4),
 kStatus_SAI_TxIdle = MAKE_STATUS(kStatusGroup_SAI, 5),
 kStatus SAI RxIdle = MAKE STATUS(kStatusGroup SAI, 6) }
    SAI return status.
• enum sai channel mask {
 kSAI_ChannelOMask = 1 << 0U,
 kSAI_Channel1Mask = 1 << 1U,
 kSAI Channel2Mask = 1 << 2U,
 kSAI_Channel3Mask = 1 << 3U,
 kSAI Channel4Mask = 1 << 4U,
 kSAI_Channel5Mask = 1 << 5U,
 kSAI Channel6Mask = 1 << 6U,
 kSAI Channel7Mask = 1 << 7U }
enum sai_protocol_t {
 kSAI_BusLeftJustified = 0x0U,
 kSAI_BusRightJustified,
 kSAI BusI2S,
 kSAI_BusPCMA,
 kSAI BusPCMB }
```

235

```
Define the SAI bus type.
enum sai_master_slave_t {
  kSAI_Master = 0x0U,
 kSAI_Slave = 0x1U }
    Master or slave mode.
• enum sai mono stereo t {
 kSAI_Stereo = 0x0U,
 kSAI_MonoRight,
 kSAI_MonoLeft }
    Mono or stereo audio format.
enum sai_data_order_t {
  kSAI DataLSB = 0x0U,
 kSAI_DataMSB }
    SAI data order, MSB or LSB.
enum sai_clock_polarity_t {
  kSAI_PolarityActiveHigh = 0x0U,
 kSAI_PolarityActiveLow }
    SAI clock polarity, active high or low.
enum sai_sync_mode_t {
  kSAI ModeAsync = 0x0U,
 kSAI_ModeSync,
 kSAI_ModeSyncWithOtherTx,
 kSAI_ModeSyncWithOtherRx }
    Synchronous or asynchronous mode.
enum sai_mclk_source_t {
  kSAI_MclkSourceSysclk = 0x0U,
 kSAI MclkSourceSelect1,
 kSAI_MclkSourceSelect2,
 kSAI_MclkSourceSelect3 }
    Mater clock source.
enum sai_bclk_source_t {
  kSAI_BclkSourceBusclk = 0x0U,
 kSAI_BclkSourceMclkOption1 = 0x1U,
 kSAI_BclkSourceMclkOption2 = 0x2U,
 kSAI_BclkSourceMclkOption3 = 0x3U,
 kSAI BclkSourceMclkDiv = 0x1U,
 kSAI_BclkSourceOtherSai0 = 0x2U,
 kSAI_BclkSourceOtherSai1 = 0x3U }
    Bit clock source.
enum _sai_interrupt_enable_t {
  kSAI_WordStartInterruptEnable,
 kSAI_SyncErrorInterruptEnable = I2S_TCSR_SEIE_MASK,
 kSAI_FIFOWarningInterruptEnable = I2S_TCSR_FWIE_MASK,
 kSAI FIFOErrorInterruptEnable = I2S TCSR FEIE MASK,
 kSAI FIFORequestInterruptEnable = I2S TCSR FRIE MASK }
    The SAI interrupt enable flag.
enum _sai_dma_enable_t {
```

MCUXpresso SDK API Reference Manual

### Typical use case

```
kSAI FIFOWarningDMAEnable = I2S TCSR FWDE MASK,
 kSAI_FIFORequestDMAEnable = I2S_TCSR_FRDE_MASK }
    The DMA request sources.
enum _sai_flags {
 kSAI_WordStartFlag = I2S_TCSR_WSF_MASK,
 kSAI_SyncErrorFlag = I2S_TCSR_SEF_MASK,
 kSAI_FIFOErrorFlag = I2S_TCSR_FEF_MASK,
 kSAI_FIFORequestFlag = I2S_TCSR_FRF_MASK,
 kSAI_FIFOWarningFlag = I2S_TCSR_FWF_MASK }
    The SAI status flag.
enum sai_reset_type_t {
 kSAI_ResetTypeSoftware = I2S_TCSR_SR_MASK,
 kSAI_ResetTypeFIFO = I2S_TCSR_FR_MASK,
 kSAI_ResetAll = I2S_TCSR_SR_MASK | I2S_TCSR_FR_MASK }
    The reset type.
enum sai_fifo_packing_t {
 kSAI_FifoPackingDisabled = 0x0U,
 kSAI_FifoPacking8bit = 0x2U,
 kSAI FifoPacking16bit = 0x3U }
    The SAI packing mode The mode includes 8 bit and 16 bit packing.
enum sai_sample_rate_t {
 kSAI_SampleRate8KHz = 8000U,
 kSAI SampleRate11025Hz = 11025U,
 kSAI_SampleRate12KHz = 12000U,
 kSAI_SampleRate16KHz = 16000U,
 kSAI_SampleRate22050Hz = 22050U,
 kSAI SampleRate24KHz = 24000U,
 kSAI SampleRate32KHz = 32000U,
 kSAI_SampleRate44100Hz = 44100U,
 kSAI_SampleRate48KHz = 48000U,
 kSAI SampleRate96KHz = 96000U,
 kSAI_SampleRate192KHz = 192000U,
 kSAI_SampleRate384KHz = 384000U
    Audio sample rate.
enum sai_word_width_t {
 kSAI WordWidth8bits = 8U,
 kSAI_WordWidth16bits = 16U,
 kSAI_WordWidth24bits = 24U,
 kSAI WordWidth32bits = 32U }
    Audio word width.
```

### **Driver version**

• #define FSL\_SAI\_DRIVER\_VERSION (MAKE\_VERSION(2, 1, 7)) *Version 2.1.7.* 

### MCUXpresso SDK API Reference Manual

### Initialization and deinitialization

- void SAI\_TxInit (I2S\_Type \*base, const sai\_config\_t \*config)

  Initializes the SAI Tx peripheral.
- void SAI\_RxInit (I2S\_Type \*base, const sai\_config\_t \*config)

  Initializes the SAI Rx peripheral.
- void SAI\_TxGetDefaultConfig (sai\_config\_t \*config)

Sets the SAI Tx configuration structure to default values.

void SAI\_RxGetDefaultConfig (sai\_config\_t \*config)

*Sets the SAI Rx configuration structure to default values.* 

• void SAI\_Deinit (I2S\_Type \*base)

*De-initializes the SAI peripheral.* 

• void SAI\_TxReset (I2S\_Type \*base)

*Resets the SAI Tx.* 

• void SAI\_RxReset (I2S\_Type \*base)

Resets the SAI Rx.

• void SAI\_TxEnable (I2S\_Type \*base, bool enable)

Enables/disables the SAI Tx.

• void SAI\_RxEnable (I2S\_Type \*base, bool enable)

Enables/disables the SAI Rx.

### **Status**

• static uint32\_t SAI\_TxGetStatusFlag (I2S\_Type \*base)

Gets the SAI Tx status flag state.

• static void SAI\_TxClearStatusFlags (I2S\_Type \*base, uint32\_t mask)

Clears the SAI Tx status flag state.

• static uint32\_t SAI\_RxGetStatusFlag (I2S\_Type \*base)

Gets the SAI Tx status flag state.

• static void SAI\_RxClearStatusFlags (I2S\_Type \*base, uint32\_t mask)

Clears the SAI Rx status flag state.

• void SAI\_TxSoftwareReset (I2S\_Type \*base, sai\_reset\_type\_t type)

Do software reset or FIFO reset.

- void SAI\_RxSoftwareReset (I2S\_Type \*base, sai\_reset\_type\_t type)

  Do software reset or FIFO reset.
- void SAI\_TxSetChannelFIFOMask (I2S\_Type \*base, uint8\_t mask)
- Set the Tx channel FIFO enable mask.

   void SAI\_RxSetChannelFIFOMask (I2S\_Type \*base, uint8\_t mask)
- Set the Rx channel FIFO enable mask.

   void SAI TxSetDataOrder (I2S Type \*base, sai data order t order)
- Void SAI\_IXSetDataOrder (12S\_Type \*base, Sai\_data\_order\_t order)

  Set the Tx data order.
- void SAI\_RxSetDataOrder (I2S\_Type \*base, sai\_data\_order\_t order)

  Set the Rx data order.
- void SAI\_TxSetBitClockPolarity (I2S\_Type \*base, sai\_clock\_polarity\_t polarity)

  Set the Tx data order.
- void SAI\_RxSetBitClockPolarity (I2S\_Type \*base, sai\_clock\_polarity\_t polarity)

  Set the Rx data order.
- void SAI\_TxSetFrameSyncPolarity (I2S\_Type \*base, sai\_clock\_polarity\_t polarity) Set the Tx data order.
- void SAI\_RxSetFrameSyncPolarity (I2S\_Type \*base, sai\_clock\_polarity\_t polarity) Set the Rx data order.
- void SAI\_TxSetFIFOPacking (I2S\_Type \*base, sai\_fifo\_packing\_t pack)

### MCUXpresso SDK API Reference Manual

### Typical use case

Set Tx FIFO packing feature.

- void SAI\_RxSetFIFOPacking (I2S\_Type \*base, sai\_fifo\_packing\_t pack)

  Set Rx FIFO packing feature.
- static void SAI\_TxSetFIFOErrorContinue (I2S\_Type \*base, bool isEnabled) Set Tx FIFO error continue.
- static void SAI\_RxSetFIFOErrorContinue (I2S\_Type \*base, bool isEnabled) Set Rx FIFO error continue.

### Interrupts

- static void SAI\_TxEnableInterrupts (I2S\_Type \*base, uint32\_t mask) Enables the SAI Tx interrupt requests.
- static void SAI\_RxEnableInterrupts (I2S\_Type \*base, uint32\_t mask) Enables the SAI Rx interrupt requests.
- static void SAI\_TxDisableInterrupts (I2S\_Type \*base, uint32\_t mask)

  Disables the SAI Tx interrupt requests.
- static void SAI\_RxDisableInterrupts (I2S\_Type \*base, uint32\_t mask)

  Disables the SAI Rx interrupt requests.

### **DMA Control**

- static void SAI\_TxEnableDMA (I2S\_Type \*base, uint32\_t mask, bool enable) Enables/disables the SAI Tx DMA requests.
- static void SAI\_RxEnableDMA (I2S\_Type \*base, uint32\_t mask, bool enable) Enables/disables the SAI Rx DMA requests.
- static uint32\_t SAI\_TxGetDataRegisterAddress (I2S\_Type \*base, uint32\_t channel) Gets the SAI Tx data register address.
- static uint32\_t SAI\_RxGetDataRegisterAddress (I2S\_Type \*base, uint32\_t channel) Gets the SAI Rx data register address.

## **Bus Operations**

- void SAI\_TxSetFormat (I2S\_Type \*base, sai\_transfer\_format\_t \*format, uint32\_t mclkSource-ClockHz, uint32\_t bclkSourceClockHz)
- Configures the SAI Tx audio format.

   void SAI\_RxSetFormat (I2S\_Type \*base, sai\_transfer\_format\_t \*format, uint32\_t mclkSource-ClockHz, uint32\_t bclkSourceClockHz)

Configures the SAI Rx audio format.

• void <u>SAI\_WriteBlocking</u> (I2S\_Type \*base, uint32\_t channel, uint32\_t bitWidth, uint8\_t \*buffer, uint32\_t size)

Sends data using a blocking method.

• void SAI\_WriteMultiChannelBlocking (I2S\_Type \*base, uint32\_t channel, uint32\_t channelMask, uint32\_t bitWidth, uint8\_t \*buffer, uint32\_t size)

Sends data to multi channel using a blocking method.

- static void SAI\_WriteData (I2S\_Type \*base, uint32\_t channel, uint32\_t data) Writes data into SAI FIFO.
- void SAI\_ReadBlocking (I2S\_Type \*base, uint32\_t channel, uint32\_t bitWidth, uint8\_t \*buffer, uint32\_t size)

Receives data using a blocking method.

• void SAI\_ReadMultiChannelBlocking (I2S\_Type \*base, uint32\_t channel, uint32\_t channelMask, uint32\_t bitWidth, uint8\_t \*buffer, uint32\_t size)

Receives multi channel data using a blocking method.

• static uint32\_t SAI\_ReadData (I2S\_Type \*base, uint32\_t channel) Reads data from the SAI FIFO.

### **Transactional**

• void SAI\_TransferTxCreateHandle (I2S\_Type \*base, sai\_handle\_t \*handle, sai\_transfer\_callback\_t callback, void \*userData)

Initializes the SAI Tx handle.

• void SAI\_TransferRxCreateHandle (I2S\_Type \*base, sai\_handle\_t \*handle, sai\_transfer\_callback\_t callback, void \*userData)

*Initializes the SAI Rx handle.* 

- status\_t SAI\_TransferTxSetFormat (I2S\_Type \*base, sai\_handle\_t \*handle, sai\_transfer\_format\_t \*format, uint32\_t mclkSourceClockHz, uint32\_t bclkSourceClockHz)

  \*\*Configures the SAI Tx audio format.
- status\_t SAI\_TransferRxSetFormat (I2S\_Type \*base, sai\_handle\_t \*handle, sai\_transfer\_format\_t \*format, uint32\_t mclkSourceClockHz, uint32\_t bclkSourceClockHz)
   Configures the SAI Rx audio format.
- status\_t SAI\_TransferSendNonBlocking (I2S\_Type \*base, sai\_handle\_t \*handle, sai\_transfer\_- t \*xfer)

Performs an interrupt non-blocking send transfer on SAI.

• status\_t SAI\_TransferReceiveNonBlocking (I2S\_Type \*base, sai\_handle\_t \*handle, sai\_transfer\_t \*xfer)

Performs an interrupt non-blocking receive transfer on SAI.

- status\_t SAI\_TransferGetSendCount (I2S\_Type \*base, sai\_handle\_t \*handle, size\_t \*count) Gets a set byte count.
- status\_t SAI\_TransferGetReceiveCount (I2S\_Type \*base, sai\_handle\_t \*handle, size\_t \*count) Gets a received byte count.
- void SAI\_TransferAbortSend (I2S\_Type \*base, sai\_handle\_t \*handle)

Aborts the current send.

Terminate all SAI receive.

- void SAI\_TransferAbortReceive (I2S\_Type \*base, sai\_handle\_t \*handle)

  Aborts the current IRO receive.
- void SAI\_TransferTerminateSend (I2S\_Type \*base, sai\_handle\_t \*handle)
- *Terminate all SAI send.* void SAI\_TransferTerminateReceive (I2S\_Type \*base, sai\_handle\_t \*handle)
- void SAI\_TransferTxHandleIRQ (I2S\_Type \*base, sai\_handle\_t \*handle)

  Tx interrupt handler.
- void SAI\_TransferRxHandleIRQ (I2S\_Type \*base, sai\_handle\_t \*handle)

  Tx interrupt handler.

### **Data Structure Documentation**

### 16.3 Data Structure Documentation

### 16.3.1 struct sai\_config\_t

### **Data Fields**

• sai\_protocol\_t protocol

Audio bus protocol in SAI.

sai\_sync\_mode\_t syncMode

SAI sync mode, control Tx/Rx clock sync.

• sai\_bclk\_source\_t bclkSource

Bit Clock source.

• sai\_master\_slave\_t masterSlave

Master or slave.

### 16.3.2 struct sai transfer format t

### **Data Fields**

• uint32\_t sampleRate\_Hz

Sample rate of audio data.

• uint32\_t bitWidth

Data length of audio data, usually 8/16/24/32 bits.

• sai\_mono\_stereo\_t stereo

Mono or stereo.

• uint32 t masterClockHz

Master clock frequency in Hz.

• uint8 t watermark

Watermark value.

• uint8\_t channel

Transfer start channel.

• uint8 t channelMask

enabled channel mask value, reference sai channel mask

• uint8 t endChannel

end channel number

• uint8\_t channelNums

Total enabled channel numbers.

sai\_protocol\_t protocol

Which audio protocol used.

• bool isFrameSyncCompact

True means Frame sync length is configurable according to bitWidth, false means frame sync length is 64 times of bit clock.

### 16.3.2.0.0.17 Field Documentation

### 16.3.2.0.0.17.1 bool sai\_transfer\_format\_t::isFrameSyncCompact

### 16.3.3 struct sai transfer t

### **Data Fields**

• uint8\_t \* data

Data start address to transfer.

size\_t dataSize

Transfer size.

### 16.3.3.0.0.18 Field Documentation

16.3.3.0.0.18.1 uint8 t\* sai transfer t::data

16.3.3.0.0.18.2 size\_t sai\_transfer\_t::dataSize

### 16.3.4 struct sai handle

### **Data Fields**

• I2S\_Type \* base

base address

• uint32 t state

Transfer status.

• sai\_transfer\_callback\_t callback

Callback function called at transfer event.

void \* userĎata

Callback parameter passed to callback function.

• uint8\_t bitWidth

Bit width for transfer, 8/16/24/32 bits.

• uint8\_t channel

Transfer start channel.

• uint8\_t channelMask

enabled channel mask value, refernece sai channel mask

• uint8 t endChannel

end channel number

• uint8 t channelNums

Total enabled channel numbers.

• sai transfer t saiQueue [SAI XFER QUEUE SIZE]

Transfer queue storing queued transfer.

• size\_t transferSize [SAI\_XFER\_QUEUE\_SIZE]

Data bytes need to transfer.

• volatile uint8\_t queueUser

Index for user to queue transfer.

• volatile uint8\_t queueDriver

Index for driver to get the transfer data and size.

### **MCUXpresso SDK API Reference Manual**

### **Enumeration Type Documentation**

• uint8\_t watermark Watermark value.

### 16.4 Macro Definition Documentation

16.4.1 #define SAI\_XFER\_QUEUE\_SIZE (4)

### 16.5 Enumeration Type Documentation

16.5.1 enum \_sai\_status\_t

#### Enumerator

kStatus\_SAI\_TxBusy SAI Tx is busy.
kStatus\_SAI\_RxBusy SAI Rx is busy.
kStatus\_SAI\_TxError SAI Tx FIFO error.
kStatus\_SAI\_RxError SAI Rx FIFO error.
kStatus\_SAI\_QueueFull SAI transfer queue is full.
kStatus\_SAI\_TxIdle SAI Tx is idle.
kStatus\_SAI\_RxIdle SAI Rx is idle.

### 16.5.2 enum \_sai\_channel\_mask

#### Enumerator

kSAI\_Channel0Mask channel 0 mask value kSAI\_Channel1Mask channel 1 mask value channel 2 mask value channel 3 mask value channel 3 mask value channel 4 mask value channel 5 mask value kSAI\_Channel5Mask channel 5 mask value kSAI\_Channel6Mask channel 6 mask value channel 7 mask value channel 7 mask value channel 7 mask value

## 16.5.3 enum sai\_protocol\_t

### Enumerator

kSAI\_BusLeftJustified Uses left justified format.
kSAI\_BusRightJustified Uses right justified format.
kSAI\_BusI2S Uses I2S format.
kSAI\_BusPCMA Uses I2S PCM A format.
kSAI\_BusPCMB Uses I2S PCM B format.

### 16.5.4 enum sai\_master\_slave\_t

### Enumerator

**kSAI\_Master** Master mode. **kSAI\_Slave** Slave mode.

### 16.5.5 enum sai\_mono\_stereo\_t

#### Enumerator

kSAI\_Stereo Stereo sound.kSAI\_MonoRight Only Right channel have sound.kSAI\_MonoLeft Only left channel have sound.

### 16.5.6 enum sai\_data\_order\_t

### Enumerator

kSAI\_DataLSB LSB bit transferred first.kSAI DataMSB MSB bit transferred first.

## 16.5.7 enum sai\_clock\_polarity\_t

### Enumerator

**kSAI\_PolarityActiveHigh** Clock active high. **kSAI\_PolarityActiveLow** Clock active low.

### 16.5.8 enum sai\_sync\_mode\_t

#### Enumerator

**kSAI\_ModeAsync** Asynchronous mode.

**kSAI\_ModeSync** Synchronous mode (with receiver or transmit)

 $kSAI\_ModeSyncWithOtherTx$  Synchronous with another SAI transmit.

**kSAI\_ModeSyncWithOtherRx** Synchronous with another SAI receiver.

MCUXpresso SDK API Reference Manual

### **Enumeration Type Documentation**

### 16.5.9 enum sai\_mclk\_source\_t

### Enumerator

kSAI\_MclkSourceSysclk Master clock from the system clock.

**kSAI\_MclkSourceSelect1** Master clock from source 1.

kSAI\_MclkSourceSelect2 Master clock from source 2.

**kSAI** MclkSourceSelect3 Master clock from source 3.

### 16.5.10 enum sai\_bclk\_source\_t

### Enumerator

kSAI BclkSourceBusclk Bit clock using bus clock.

kSAI\_BclkSourceMclkOption1 Bit clock MCLK option 1.

kSAI\_BclkSourceMclkOption2 Bit clock MCLK option2.

kSAI\_BclkSourceMclkOption3 Bit clock MCLK option3.

kSAI\_BclkSourceMclkDiv Bit clock using master clock divider.

kSAI\_BclkSourceOtherSaiO Bit clock from other SAI device.

kSAI BclkSourceOtherSai1 Bit clock from other SAI device.

### 16.5.11 enum \_sai\_interrupt\_enable\_t

### Enumerator

**kSAI\_WordStartInterruptEnable** Word start flag, means the first word in a frame detected.

**kSAI** SyncErrorInterruptEnable Sync error flag, means the sync error is detected.

kSAI FIFOWarningInterruptEnable FIFO warning flag, means the FIFO is empty.

**kSAI\_FIFOErrorInterruptEnable** FIFO error flag.

**kSAI\_FIFORequestInterruptEnable** FIFO request, means reached watermark.

### 16.5.12 enum \_sai\_dma\_enable\_t

### Enumerator

kSAI\_FIFOWarningDMAEnable FIFO warning caused by the DMA request.

kSAI\_FIFORequestDMAEnable FIFO request caused by the DMA request.

### 16.5.13 enum sai\_flags

### Enumerator

**kSAI\_WordStartFlag** Word start flag, means the first word in a frame detected.

kSAI\_SyncErrorFlag Sync error flag, means the sync error is detected.

kSAI\_FIFOErrorFlag FIFO error flag.

kSAI\_FIFORequestFlag FIFO request flag.

kSAI\_FIFOWarningFlag FIFO warning flag.

### 16.5.14 enum sai\_reset\_type\_t

### Enumerator

**kSAI\_ResetTypeSoftware** Software reset, reset the logic state.

**kSAI\_ResetTypeFIFO** FIFO reset, reset the FIFO read and write pointer.

kSAI ResetAll All reset.

### 16.5.15 enum sai\_fifo\_packing\_t

### Enumerator

kSAI FifoPackingDisabled Packing disabled.

kSAI FifoPacking8bit 8 bit packing enabled

kSAI\_FifoPacking16bit 16bit packing enabled

### 16.5.16 enum sai\_sample\_rate\_t

### Enumerator

kSAI\_SampleRate8KHz Sample rate 8000 Hz.

kSAI\_SampleRate11025Hz Sample rate 11025 Hz.

kSAI SampleRate12KHz Sample rate 12000 Hz.

**kSAI\_SampleRate16KHz** Sample rate 16000 Hz.

kSAI\_SampleRate22050Hz Sample rate 22050 Hz.

**kSAI\_SampleRate24KHz** Sample rate 24000 Hz.

*kSAI\_SampleRate32KHz* Sample rate 32000 Hz.

kSAI SampleRate44100Hz Sample rate 44100 Hz.

kSAI\_SampleRate48KHz Sample rate 48000 Hz.

**kSAI\_SampleRate96KHz** Sample rate 96000 Hz.

**kSAI** SampleRate192KHz Sample rate 192000 Hz.

**kSAI\_SampleRate384KHz** Sample rate 384000 Hz.

MCUXpresso SDK API Reference Manual

### 16.5.17 enum sai\_word\_width\_t

### Enumerator

kSAI\_WordWidth8bits Audio data width 8 bits.
 kSAI\_WordWidth16bits Audio data width 16 bits.
 kSAI\_WordWidth24bits Audio data width 24 bits.
 kSAI WordWidth32bits Audio data width 32 bits.

### 16.6 Function Documentation

### 16.6.1 void SAI\_TxInit ( I2S\_Type \* base, const sai\_config\_t \* config )

Ungates the SAI clock, resets the module, and configures SAI Tx with a configuration structure. The configuration structure can be custom filled or set with default values by SAI\_TxGetDefaultConfig().

### Note

This API should be called at the beginning of the application to use the SAI driver. Otherwise, accessing the SAIM module can cause a hard fault because the clock is not enabled.

### **Parameters**

| base   | SAI base pointer             |
|--------|------------------------------|
| config | SAI configuration structure. |

## 16.6.2 void SAI\_RxInit ( I2S\_Type \* base, const sai\_config\_t \* config )

Ungates the SAI clock, resets the module, and configures the SAI Rx with a configuration structure. The configuration structure can be custom filled or set with default values by SAI RxGetDefaultConfig().

### Note

This API should be called at the beginning of the application to use the SAI driver. Otherwise, accessing the SAI module can cause a hard fault because the clock is not enabled.

## Parameters

| base   | SAI base pointer             |
|--------|------------------------------|
| config | SAI configuration structure. |

### 16.6.3 void SAI\_TxGetDefaultConfig ( sai\_config\_t \* config )

This API initializes the configuration structure for use in SAI\_TxConfig(). The initialized structure can remain unchanged in SAI\_TxConfig(), or it can be modified before calling SAI\_TxConfig(). This is an example.

```
sai_config_t config;
SAI_TxGetDefaultConfig(&config);
```

### **Parameters**

| config | pointer to master configuration structure |
|--------|-------------------------------------------|
|--------|-------------------------------------------|

### 16.6.4 void SAI\_RxGetDefaultConfig ( sai\_config\_t \* config )

This API initializes the configuration structure for use in SAI\_RxConfig(). The initialized structure can remain unchanged in SAI\_RxConfig() or it can be modified before calling SAI\_RxConfig(). This is an example.

```
sai_config_t config;
SAI_RxGetDefaultConfig(&config);
```

### **Parameters**

| config | pointer to master configuration structure |
|--------|-------------------------------------------|
|--------|-------------------------------------------|

## 16.6.5 void SAI\_Deinit ( I2S\_Type \* base )

This API gates the SAI clock. The SAI module can't operate unless SAI\_TxInit or SAI\_RxInit is called to enable the clock.

Parameters

**MCUXpresso SDK API Reference Manual** 

| base | SAI base pointer |
|------|------------------|
|------|------------------|

### 16.6.6 void SAI\_TxReset ( I2S\_Type \* base )

This function enables the software reset and FIFO reset of SAI Tx. After reset, clear the reset bit.

### **Parameters**

| base | SAI base pointer |
|------|------------------|
|------|------------------|

### 16.6.7 void SAI\_RxReset ( I2S\_Type \* base )

This function enables the software reset and FIFO reset of SAI Rx. After reset, clear the reset bit.

### **Parameters**

| base | SAI base pointer |
|------|------------------|
|------|------------------|

## 16.6.8 void SAI\_TxEnable ( I2S\_Type \* base, bool enable )

### **Parameters**

| base   | SAI base pointer                               |
|--------|------------------------------------------------|
| enable | True means enable SAI Tx, false means disable. |

## 16.6.9 void SAI\_RxEnable ( I2S\_Type \* base, bool enable )

### **Parameters**

| base   | SAI base pointer                               |
|--------|------------------------------------------------|
| enable | True means enable SAI Rx, false means disable. |

## 16.6.10 static uint32\_t SAI\_TxGetStatusFlag ( I2S\_Type \* base ) [inline], [static]

### MCUXpresso SDK API Reference Manual

### **Parameters**

| base | SAI base pointer |
|------|------------------|
|------|------------------|

### Returns

SAI Tx status flag value. Use the Status Mask to get the status value needed.

## 16.6.11 static void SAI\_TxClearStatusFlags ( I2S\_Type \* base, uint32\_t mask ) [inline], [static]

### **Parameters**

| base | SAI base pointer                                                                                                                          |
|------|-------------------------------------------------------------------------------------------------------------------------------------------|
| mask | State mask. It can be a combination of the following source if defined:  • kSAI_WordStartFlag  • kSAI_SyncErrorFlag  • kSAI_FIFOErrorFlag |

## 16.6.12 static uint32\_t SAI\_RxGetStatusFlag ( I2S\_Type \* base ) [inline], [static]

### **Parameters**

| 1    | CATI             |
|------|------------------|
| base | SAI base pointer |
|      | r                |

### Returns

SAI Rx status flag value. Use the Status Mask to get the status value needed.

## 16.6.13 static void SAI\_RxClearStatusFlags ( I2S\_Type \* base, uint32\_t mask ) [inline], [static]

#### **Parameters**

| base | SAI base pointer                                                                                                                           |
|------|--------------------------------------------------------------------------------------------------------------------------------------------|
| mask | State mask. It can be a combination of the following sources if defined.  • kSAI_WordStartFlag  • kSAI_SyncErrorFlag  • kSAI_FIFOErrorFlag |

## 16.6.14 void SAI\_TxSoftwareReset ( I2S\_Type \* base, sai\_reset\_type\_t type )

FIFO reset means clear all the data in the FIFO, and make the FIFO pointer both to 0. Software reset means claer the Tx internal logic, including the bit clock, frame count etc. But software reset will not clear any configuration registers like TCR1~TCR5. This function will also clear all the error flags such as FIFO error, sync error etc.

#### **Parameters**

| base | SAI base pointer                         |
|------|------------------------------------------|
| type | Reset type, FIFO reset or software reset |

## 16.6.15 void SAI\_RxSoftwareReset ( I2S\_Type \* base, sai\_reset\_type\_t type )

FIFO reset means clear all the data in the FIFO, and make the FIFO pointer both to 0. Software reset means claer the Rx internal logic, including the bit clock, frame count etc. But software reset will not clear any configuration registers like RCR1~RCR5. This function will also clear all the error flags such as FIFO error, sync error etc.

### **Parameters**

| base | SAI base pointer                         |
|------|------------------------------------------|
| type | Reset type, FIFO reset or software reset |

## 16.6.16 void SAI\_TxSetChannelFIFOMask ( I2S\_Type \* base, uint8\_t mask )

MCUXpresso SDK API Reference Manual

### **Parameters**

| base | SAI base pointer                                                                   |
|------|------------------------------------------------------------------------------------|
| mask | Channel enable mask, 0 means all channel FIFO disabled, 1 means channel 0 enabled, |
|      | 3 means both channel 0 and channel 1 enabled.                                      |

## 16.6.17 void SAI\_RxSetChannelFIFOMask ( I2S\_Type \* base, uint8\_t mask )

### **Parameters**

| base | SAI base pointer                                                                   |
|------|------------------------------------------------------------------------------------|
| mask | Channel enable mask, 0 means all channel FIFO disabled, 1 means channel 0 enabled, |
|      | 3 means both channel 0 and channel 1 enabled.                                      |

### 16.6.18 void SAI\_TxSetDataOrder ( I2S\_Type \* base, sai\_data\_order\_t order )

### Parameters

| base  | SAI base pointer      |
|-------|-----------------------|
| order | Data order MSB or LSB |

## 16.6.19 void SAI RxSetDataOrder ( I2S Type \* base, sai\_data\_order\_t order )

### **Parameters**

| base  | SAI base pointer      |
|-------|-----------------------|
| order | Data order MSB or LSB |

## 16.6.20 void SAI\_TxSetBitClockPolarity ( I2S\_Type \* base, sai\_clock\_polarity\_t polarity )

MCUXpresso SDK API Reference Manual

### **Parameters**

| base  | SAI base pointer      |
|-------|-----------------------|
| order | Data order MSB or LSB |

## 16.6.21 void SAI\_RxSetBitClockPolarity ( I2S\_Type \* base, sai\_clock\_polarity\_t polarity )

### Parameters

| base  | SAI base pointer      |
|-------|-----------------------|
| order | Data order MSB or LSB |

## 16.6.22 void SAI\_TxSetFrameSyncPolarity ( I2S\_Type \* base, sai\_clock\_polarity\_t polarity )

### **Parameters**

| base  | SAI base pointer      |
|-------|-----------------------|
| order | Data order MSB or LSB |

## 16.6.23 void SAI\_RxSetFrameSyncPolarity ( I2S\_Type \* base, sai\_clock\_polarity\_t polarity )

### **Parameters**

| base  | SAI base pointer      |
|-------|-----------------------|
| order | Data order MSB or LSB |

## 16.6.24 void SAI\_TxSetFIFOPacking ( I2S\_Type \* base, sai\_fifo\_packing\_t pack )

253

#### **Parameters**

| base | SAI base pointer.                                    |
|------|------------------------------------------------------|
| pack | FIFO pack type. It is element of sai_fifo_packing_t. |

### 16.6.25 void SAI\_RxSetFIFOPacking ( I2S\_Type \* base, sai\_fifo\_packing\_t pack )

#### **Parameters**

| base | SAI base pointer.                                    |
|------|------------------------------------------------------|
| pack | FIFO pack type. It is element of sai_fifo_packing_t. |

## 16.6.26 static void SAI\_TxSetFIFOErrorContinue ( I2S\_Type \* base, bool isEnabled ) [inline], [static]

FIFO error continue mode means SAI will keep running while FIFO error occured. If this feature not enabled, SAI will hang and users need to clear FEF flag in TCSR register.

### **Parameters**

| base      | SAI base pointer.                                                       |
|-----------|-------------------------------------------------------------------------|
| isEnabled | Is FIFO error continue enabled, true means enable, false means disable. |

## 16.6.27 static void SAI\_RxSetFIFOErrorContinue ( I2S\_Type \* base, bool isEnabled ) [inline], [static]

FIFO error continue mode means SAI will keep running while FIFO error occured. If this feature not enabled, SAI will hang and users need to clear FEF flag in RCSR register.

### **Parameters**

| base      | SAI base pointer.                                                       |
|-----------|-------------------------------------------------------------------------|
| isEnabled | Is FIFO error continue enabled, true means enable, false means disable. |

## 16.6.28 static void SAI\_TxEnableInterrupts ( I2S\_Type \* base, uint32\_t mask ) [inline], [static]

### Parameters

| base | SAI base pointer                                                                                                                                                                                                                                                                                                              |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mask | <ul> <li>interrupt source The parameter can be a combination of the following sources if defined.</li> <li>• kSAI_WordStartInterruptEnable</li> <li>• kSAI_SyncErrorInterruptEnable</li> <li>• kSAI_FIFOWarningInterruptEnable</li> <li>• kSAI_FIFORequestInterruptEnable</li> <li>• kSAI_FIFOErrorInterruptEnable</li> </ul> |

## 16.6.29 static void SAI\_RxEnableInterrupts ( I2S\_Type \* base, uint32\_t mask ) [inline], [static]

### Parameters

| base | SAI base pointer                                                                                                                                                                                                                                                                                                              |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mask | <ul> <li>interrupt source The parameter can be a combination of the following sources if defined.</li> <li>• kSAI_WordStartInterruptEnable</li> <li>• kSAI_SyncErrorInterruptEnable</li> <li>• kSAI_FIFOWarningInterruptEnable</li> <li>• kSAI_FIFORequestInterruptEnable</li> <li>• kSAI_FIFOErrorInterruptEnable</li> </ul> |

MCUXpresso SDK API Reference Manual **NXP Semiconductors** 254

255

## 16.6.30 static void SAI\_TxDisableInterrupts ( I2S\_Type \* base, uint32\_t mask ) [inline], [static]

### Parameters

| base | SAI base pointer                                                                    |
|------|-------------------------------------------------------------------------------------|
| mask | interrupt source The parameter can be a combination of the following sources if de- |
|      | fined.                                                                              |
|      | <ul> <li>kSAI_WordStartInterruptEnable</li> </ul>                                   |
|      | <ul> <li>kSAI_SyncErrorInterruptEnable</li> </ul>                                   |
|      | <ul> <li>kSAI_FIFOWarningInterruptEnable</li> </ul>                                 |
|      | <ul> <li>kSAI_FIFORequestInterruptEnable</li> </ul>                                 |
|      | • kSAI_FIFOErrorInterruptEnable                                                     |
|      | •                                                                                   |

## 16.6.31 static void SAI\_RxDisableInterrupts ( I2S\_Type \* base, uint32\_t mask ) [inline], [static]

### Parameters

| base | SAI base pointer                                                                    |
|------|-------------------------------------------------------------------------------------|
| mask | interrupt source The parameter can be a combination of the following sources if de- |
|      | fined.                                                                              |
|      | kSAI_WordStartInterruptEnable                                                       |
|      | kSAI_SyncErrorInterruptEnable                                                       |
|      | <ul> <li>kSAI_FIFOWarningInterruptEnable</li> </ul>                                 |
|      | <ul> <li>kSAI_FIFORequestInterruptEnable</li> </ul>                                 |
|      | kSAI_FIFOErrorInterruptEnable                                                       |
|      |                                                                                     |

## 16.6.32 static void SAI\_TxEnableDMA ( I2S\_Type \* base, uint32\_t mask, bool enable ) [inline], [static]

| Parameters |
|------------|
|------------|

| base   | SAI base pointer                                                                                                                           |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------|
| mask   | DMA source The parameter can be combination of the following sources if defined.  • kSAI_FIFOWarningDMAEnable  • kSAI_FIFORequestDMAEnable |
| enable | True means enable DMA, false means disable DMA.                                                                                            |

## 16.6.33 static void SAI\_RxEnableDMA ( I2S\_Type \* base, uint32\_t mask, bool enable ) [inline], [static]

#### **Parameters**

| base   | SAI base pointer                                                                                                                             |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------|
| mask   | DMA source The parameter can be a combination of the following sources if defined.  • kSAI_FIFOWarningDMAEnable  • kSAI_FIFORequestDMAEnable |
| enable | True means enable DMA, false means disable DMA.                                                                                              |

## 16.6.34 static uint32\_t SAI\_TxGetDataRegisterAddress ( I2S\_Type \* base, uint32\_t channel ) [inline], [static]

This API is used to provide a transfer address for the SAI DMA transfer configuration.

### **Parameters**

| base    | SAI base pointer.        |
|---------|--------------------------|
| channel | Which data channel used. |

### Returns

data register address.

## 16.6.35 static uint32\_t SAI\_RxGetDataRegisterAddress ( I2S\_Type \* base, uint32\_t channel ) [inline], [static]

This API is used to provide a transfer address for the SAI DMA transfer configuration.

### **MCUXpresso SDK API Reference Manual**

### **Parameters**

| base    | SAI base pointer.        |
|---------|--------------------------|
| channel | Which data channel used. |

### Returns

data register address.

## 16.6.36 void SAI\_TxSetFormat ( I2S\_Type \* base, sai\_transfer\_format\_t \* format, uint32 t mclkSourceClockHz, uint32 t bclkSourceClockHz )

The audio format can be changed at run-time. This function configures the sample rate and audio data format to be transferred.

### **Parameters**

| base                   | SAI base pointer.                                                                                                           |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| format                 | Pointer to the SAI audio data format structure.                                                                             |
| mclkSource-<br>ClockHz | SAI master clock source frequency in Hz.                                                                                    |
| bclkSource-<br>ClockHz | SAI bit clock source frequency in Hz. If the bit clock source is a master clock, this value should equal the masterClockHz. |

## 16.6.37 void SAI\_RxSetFormat ( I2S\_Type \* base, sai\_transfer\_format\_t \* format, uint32 t mclkSourceClockHz, uint32 t bclkSourceClockHz )

The audio format can be changed at run-time. This function configures the sample rate and audio data format to be transferred.

### Parameters

| base                   | SAI base pointer.                               |
|------------------------|-------------------------------------------------|
| format                 | Pointer to the SAI audio data format structure. |
| mclkSource-<br>ClockHz | 1 2                                             |
| bclkSource-<br>ClockHz | 1 7                                             |

## 16.6.38 void SAI\_WriteBlocking ( I2S\_Type \* base, uint32\_t channel, uint32\_t bitWidth, uint8\_t \* buffer, uint32\_t size )

Note

This function blocks by polling until data is ready to be sent.

### **Parameters**

| base     | SAI base pointer.                                        |
|----------|----------------------------------------------------------|
| channel  | Data channel used.                                       |
| bitWidth | How many bits in an audio word; usually 8/16/24/32 bits. |
| buffer   | Pointer to the data to be written.                       |
| size     | Bytes to be written.                                     |

## 16.6.39 void SAI\_WriteMultiChannelBlocking ( I2S\_Type \* base, uint32\_t channel, uint32\_t channelMask, uint32\_t bitWidth, uint8\_t \* buffer, uint32\_t size )

Note

This function blocks by polling until data is ready to be sent.

### Parameters

| base        | SAI base pointer.                                        |
|-------------|----------------------------------------------------------|
| channel     | Data channel used.                                       |
| channelMask | channel mask.                                            |
| bitWidth    | How many bits in an audio word; usually 8/16/24/32 bits. |
| buffer      | Pointer to the data to be written.                       |
| size        | Bytes to be written.                                     |

## 16.6.40 static void SAI\_WriteData ( I2S\_Type \* base, uint32\_t channel, uint32\_t data ) [inline], [static]

### **Parameters**

| base    | SAI base pointer.         |
|---------|---------------------------|
| channel | Data channel used.        |
| data    | Data needs to be written. |

## 16.6.41 void SAI\_ReadBlocking ( I2S\_Type \* base, uint32\_t channel, uint32\_t bitWidth, uint8\_t \* buffer, uint32\_t size )

Note

This function blocks by polling until data is ready to be sent.

### Parameters

| base     | SAI base pointer.                                        |
|----------|----------------------------------------------------------|
| channel  | Data channel used.                                       |
| bitWidth | How many bits in an audio word; usually 8/16/24/32 bits. |
| buffer   | Pointer to the data to be read.                          |
| size     | Bytes to be read.                                        |

## 16.6.42 void SAI\_ReadMultiChannelBlocking ( I2S\_Type \* base, uint32\_t channel, uint32\_t channelMask, uint32\_t bitWidth, uint8\_t \* buffer, uint32\_t size )

Note

This function blocks by polling until data is ready to be sent.

### **Parameters**

| base        | SAI base pointer.                                        |
|-------------|----------------------------------------------------------|
| channel     | Data channel used.                                       |
| channelMask | channel mask.                                            |
| bitWidth    | How many bits in an audio word; usually 8/16/24/32 bits. |
| buffer      | Pointer to the data to be read.                          |
| size        | Bytes to be read.                                        |

16.6.43 static uint32\_t SAI\_ReadData ( I2S\_Type \* base, uint32\_t channel ) [inline], [static]

### **Parameters**

| base    | SAI base pointer.  |
|---------|--------------------|
| channel | Data channel used. |

### Returns

Data in SAI FIFO.

## 16.6.44 void SAI\_TransferTxCreateHandle ( I2S\_Type \* base, sai\_handle\_t \* handle, sai\_transfer\_callback\_t callback, void \* userData )

This function initializes the Tx handle for the SAI Tx transactional APIs. Call this function once to get the handle initialized.

### **Parameters**

| base     | SAI base pointer                               |
|----------|------------------------------------------------|
| handle   | SAI handle pointer.                            |
| callback | Pointer to the user callback function.         |
| userData | User parameter passed to the callback function |

## 16.6.45 void SAI\_TransferRxCreateHandle ( I2S\_Type \* base, sai\_handle\_t \* handle, sai\_transfer\_callback\_t callback, void \* userData )

This function initializes the Rx handle for the SAI Rx transactional APIs. Call this function once to get the handle initialized.

### Parameters

| base     | SAI base pointer.                               |
|----------|-------------------------------------------------|
| handle   | SAI handle pointer.                             |
| callback | Pointer to the user callback function.          |
| userData | User parameter passed to the callback function. |

16.6.46 status\_t SAI\_TransferTxSetFormat ( I2S\_Type \* base, sai\_handle\_t \* handle, sai\_transfer\_format\_t \* format, uint32\_t mclkSourceClockHz, uint32\_t bclkSourceClockHz )

The audio format can be changed at run-time. This function configures the sample rate and audio data format to be transferred.

263

### **Parameters**

| base                   | SAI base pointer.                                                                                                                   |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| handle                 | SAI handle pointer.                                                                                                                 |
| format                 | Pointer to the SAI audio data format structure.                                                                                     |
| mclkSource-<br>ClockHz | SAI master clock source frequency in Hz.                                                                                            |
| bclkSource-<br>ClockHz | SAI bit clock source frequency in Hz. If a bit clock source is a master clock, this value should equal the masterClockHz in format. |

### Returns

Status of this function. Return value is the status t.

# 16.6.47 status\_t SAI\_TransferRxSetFormat ( I2S\_Type \* base, sai\_handle\_t \* handle, sai\_transfer\_format\_t \* format, uint32\_t mclkSourceClockHz, uint32\_t bclkSourceClockHz)

The audio format can be changed at run-time. This function configures the sample rate and audio data format to be transferred.

#### **Parameters**

| base                   | SAI base pointer.                                                                                                                   |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| handle                 | SAI handle pointer.                                                                                                                 |
| format                 | Pointer to the SAI audio data format structure.                                                                                     |
| mclkSource-<br>ClockHz | SAI master clock source frequency in Hz.                                                                                            |
| bclkSource-<br>ClockHz | SAI bit clock source frequency in Hz. If a bit clock source is a master clock, this value should equal the masterClockHz in format. |

### Returns

Status of this function. Return value is one of status\_t.

## 16.6.48 status\_t SAI\_TransferSendNonBlocking ( I2S\_Type \* base, sai\_handle\_t \* handle, sai\_transfer\_t \* xfer )

### Note

This API returns immediately after the transfer initiates. Call the SAI\_TxGetTransferStatusIRQ to poll the transfer status and check whether the transfer is finished. If the return status is not kStatus\_-SAI\_Busy, the transfer is finished.

### **Parameters**

| base   | SAI base pointer.                                                      |
|--------|------------------------------------------------------------------------|
| handle | Pointer to the sai_handle_t structure which stores the transfer state. |
| xfer   | Pointer to the sai_transfer_t structure.                               |

### Return values

| kStatus_Success         | Successfully started the data receive. |
|-------------------------|----------------------------------------|
| kStatus_SAI_TxBusy      | Previous receive still not finished.   |
| kStatus_InvalidArgument | The input parameter is invalid.        |

## 16.6.49 status\_t SAI\_TransferReceiveNonBlocking ( I2S\_Type \* base, sai\_handle\_t \* handle, sai\_transfer\_t \* xfer )

### Note

This API returns immediately after the transfer initiates. Call the SAI\_RxGetTransferStatusIRQ to poll the transfer status and check whether the transfer is finished. If the return status is not kStatus\_-SAI\_Busy, the transfer is finished.

### **Parameters**

| base   | SAI base pointer                                                       |
|--------|------------------------------------------------------------------------|
| handle | Pointer to the sai_handle_t structure which stores the transfer state. |
| xfer   | Pointer to the sai_transfer_t structure.                               |

### Return values

| kStatus_Success         | Successfully started the data receive. |
|-------------------------|----------------------------------------|
| kStatus_SAI_RxBusy      | Previous receive still not finished.   |
| kStatus_InvalidArgument | The input parameter is invalid.        |

MCUXpresso SDK API Reference Manual

16.6.50 status\_t SAI\_TransferGetSendCount ( I2S\_Type \* base, sai\_handle\_t \* handle, size\_t \* count )

### Parameters

| base   | SAI base pointer.                                                      |
|--------|------------------------------------------------------------------------|
| handle | Pointer to the sai_handle_t structure which stores the transfer state. |
| count  | Bytes count sent.                                                      |

### Return values

| kStatus_Success                   | Succeed get the transfer count.                                |
|-----------------------------------|----------------------------------------------------------------|
| kStatus_NoTransferIn-<br>Progress | There is not a non-blocking transaction currently in progress. |

## 16.6.51 status\_t SAI\_TransferGetReceiveCount ( I2S\_Type \* base, sai\_handle\_t \* handle, size t \* count )

### **Parameters**

| base   | SAI base pointer.                                                      |
|--------|------------------------------------------------------------------------|
| handle | Pointer to the sai_handle_t structure which stores the transfer state. |
| count  | Bytes count received.                                                  |

### Return values

| kStatus_Success | Succeed get the transfer count.                                |
|-----------------|----------------------------------------------------------------|
|                 | There is not a non-blocking transaction currently in progress. |
| Progress        | There is not a non-blocking transaction currently in progress. |

## $\textbf{16.6.52} \quad \textbf{void SAI\_TransferAbortSend ( } \textbf{I2S\_Type} * \textbf{\textit{base}, } \textbf{sai\_handle\_t} * \textbf{\textit{handle} } \textbf{)}$

### Note

This API can be called any time when an interrupt non-blocking transfer initiates to abort the transfer early.

MCUXpresso SDK API Reference Manual

### **Parameters**

| base   | SAI base pointer.                                                      |
|--------|------------------------------------------------------------------------|
| handle | Pointer to the sai_handle_t structure which stores the transfer state. |

### 16.6.53 void SAI\_TransferAbortReceive ( I2S\_Type \* base, sai\_handle\_t \* handle )

Note

This API can be called when an interrupt non-blocking transfer initiates to abort the transfer early.

### **Parameters**

| base   | SAI base pointer                                                       |
|--------|------------------------------------------------------------------------|
| handle | Pointer to the sai_handle_t structure which stores the transfer state. |

## 16.6.54 void SAI\_TransferTerminateSend ( I2S\_Type \* base, sai\_handle\_t \* handle )

This function will clear all transfer slots buffered in the sai queue. If users only want to abort the current transfer slot, please call SAI\_TransferAbortSend.

### Parameters

| base   | SAI base pointer.        |
|--------|--------------------------|
| handle | SAI eDMA handle pointer. |

## 16.6.55 void SAI\_TransferTerminateReceive ( I2S\_Type \* base, sai\_handle\_t \* handle )

This function will clear all transfer slots buffered in the sai queue. If users only want to abort the current transfer slot, please call SAI\_TransferAbortReceive.

Parameters

### MCUXpresso SDK API Reference Manual

| base   | SAI base pointer.        |
|--------|--------------------------|
| handle | SAI eDMA handle pointer. |

## 16.6.56 void SAI\_TransferTxHandleIRQ ( I2S\_Type \* base, sai\_handle\_t \* handle )

### Parameters

| base   | SAI base pointer.                      |
|--------|----------------------------------------|
| handle | Pointer to the sai_handle_t structure. |

## 16.6.57 void SAI\_TransferRxHandleIRQ ( I2S\_Type \* base, sai\_handle\_t \* handle )

### **Parameters**

| base   | SAI base pointer.                      |
|--------|----------------------------------------|
| handle | Pointer to the sai_handle_t structure. |

## 16.7 SAI DMA Driver

## **SAI EDMA Driver**

### 16.8 SAI EDMA Driver

**SAI SDMA Driver** 

# 16.9 SAI SDMA Driver

# **SAI SDMA Driver**

# **Chapter 17 SEMA4: Hardware Semaphores Driver**

#### 17.1 Overview

The MCUXpresso SDK provides a driver for the SEMA4 module of MCUXpresso SDK devices.

#### **Macros**

• #define SEMA4\_GATE\_NUM\_RESET\_ALL (64U)

The number to reset all SEMA4 gates.

• #define SEMA4\_GATEn(base, n) (\*(&((base)->Gate00) + (n)))

SEMA4 gate n register address.

## **Functions**

• void SEMA4\_Init (SEMA4\_Type \*base)

Initializes the SEMA4 module.

• void SEMA4\_Deinit (SEMA4\_Type \*base)

De-initializes the SEMA4 module.

• status\_t SEMA4\_TryLock (SEMA4\_Type \*base, uint8\_t gateNum, uint8\_t procNum)

Tries to lock the SEMA4 gate.

• void SEMA4 Lock (SEMA4 Type \*base, uint8 t gateNum, uint8 t procNum)

Locks the SEMA4 gate.

• static void SEMA4\_Unlock (SEMA4\_Type \*base, uint8\_t gateNum)

Unlocks the SEMA4 gate.

• static int32\_t SEMA4\_GetLockProc (SEMA4\_Type \*base, uint8\_t gateNum)

Gets the status of the SEMA4 gate.

• status\_t SEMA4\_ResetGate (SEMA4\_Type \*base, uint8\_t gateNum)

Resets the SEMA4 gate to an unlocked status.

• static status\_t SEMA4\_ResetAllGates (SEMA4\_Type \*base)

Resets all SEMA4 gates to an unlocked status.

• static void SEMA4\_EnableGateNotifyInterrupt (SEMA4\_Type \*base, uint8\_t procNum, uint32\_t mask)

*Enable the gate notification interrupt.* 

static void SEMA4\_DisableGateNotifyInterrupt (SEMA4\_Type \*base, uint8\_t procNum, uint32\_t mask)

Disable the gate notification interrupt.

• static uint32\_t SEMA4\_GetGateNotifyStatus (SEMA4\_Type \*base, uint8\_t procNum)

*Get the gate notification flags.* 

• status\_t SEMA4\_ResetGateNotify (SEMA4\_Type \*base, uint8\_t gateNum)

Resets the SEMA4 gate IRQ notification.

• static status\_t SEMA4\_ResetAllGateNotify (SEMA4\_Type \*base)

Resets all SEMA4 gates IRQ notification.

## **Driver version**

• #define FSL\_SEMA4\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 0)) SEMA4 driver version.

## 17.2 Macro Definition Documentation

## 17.2.1 #define SEMA4 GATE NUM RESET ALL (64U)

## 17.3 Function Documentation

## 17.3.1 void SEMA4 Init ( SEMA4 Type \* base )

This function initializes the SEMA4 module. It only enables the clock but does not reset the gates because the module might be used by other processors at the same time. To reset the gates, call either SEMA4\_ResetGate or SEMA4\_ResetAllGates function.

#### **Parameters**

| base | SEMA4 peripheral base address. |
|------|--------------------------------|
|------|--------------------------------|

## 17.3.2 void SEMA4\_Deinit ( SEMA4\_Type \* base )

This function de-initializes the SEMA4 module. It only disables the clock.

#### **Parameters**

| base | SEMA4 peripheral base address. |
|------|--------------------------------|

# 17.3.3 status\_t SEMA4\_TryLock ( SEMA4\_Type \* base, uint8\_t gateNum, uint8\_t procNum )

This function tries to lock the specific SEMA4 gate. If the gate has been locked by another processor, this function returns an error code.

#### **Parameters**

| base SEMA4 peripheral base address. |
|-------------------------------------|
|-------------------------------------|

| gateNum | Gate number to lock.      |
|---------|---------------------------|
| procNum | Current processor number. |

#### Return values

| kStatus_Success | Lock the sema4 gate successfully.                |
|-----------------|--------------------------------------------------|
| kStatus_Fail    | Sema4 gate has been locked by another processor. |

# 17.3.4 void SEMA4 Lock ( SEMA4 Type \* base, uint8 t gateNum, uint8 t procNum )

This function locks the specific SEMA4 gate. If the gate has been locked by other processors, this function waits until it is unlocked and then lock it.

#### **Parameters**

| base    | SEMA4 peripheral base address. |
|---------|--------------------------------|
| gateNum | Gate number to lock.           |
| procNum | Current processor number.      |

#### 17.3.5 static void SEMA4\_Unlock ( SEMA4\_Type \* base, uint8\_t gateNum ) [inline], [static]

This function unlocks the specific SEMA4 gate. It only writes unlock value to the SEMA4 gate register. However, it does not check whether the SEMA4 gate is locked by the current processor or not. As a result, if the SEMA4 gate is not locked by the current processor, this function has no effect.

#### **Parameters**

| base    | SEMA4 peripheral base address. |
|---------|--------------------------------|
| gateNum | Gate number to unlock.         |

# 17.3.6 static int32 t SEMA4 GetLockProc ( SEMA4 Type \* base, uint8 t gateNum ) [inline], [static]

This function checks the lock status of a specific SEMA4 gate.

#### **Parameters**

| base    | SEMA4 peripheral base address. |
|---------|--------------------------------|
| gateNum | Gate number.                   |

#### Returns

Return -1 if the gate is unlocked, otherwise return the processor number which has locked the gate.

# 17.3.7 status\_t SEMA4\_ResetGate ( SEMA4\_Type \* base, uint8\_t gateNum )

This function resets a SEMA4 gate to an unlocked status.

#### **Parameters**

| base    | SEMA4 peripheral base address. |
|---------|--------------------------------|
| gateNum | Gate number.                   |

## Return values

| kStatus_Success | SEMA4 gate is reset successfully.    |
|-----------------|--------------------------------------|
| kStatus_Fail    | Some other reset process is ongoing. |

# 17.3.8 static status\_t SEMA4\_ResetAllGates ( SEMA4\_Type \* base ) [inline], [static]

This function resets all SEMA4 gate to an unlocked status.

#### **Parameters**

| base | SEMA4 peripheral base address. |
|------|--------------------------------|
|------|--------------------------------|

#### Return values

| kStatus_Succes | SEMA4 is reset successfully. |
|----------------|------------------------------|
|----------------|------------------------------|

## MCUXpresso SDK API Reference Manual

277

| kStatus_Fail | Some other reset process is ongoing. |
|--------------|--------------------------------------|
|--------------|--------------------------------------|

# 17.3.9 static void SEMA4 EnableGateNotifyInterrupt ( SEMA4 Type \* base, uint8 t procNum, uint32 t mask ) [inline], [static]

Gate notification provides such feature, when core tried to lock the gate and failed, it could get notification when the gate is idle.

#### **Parameters**

| base    | SEMA4 peripheral base address.                                                             |
|---------|--------------------------------------------------------------------------------------------|
| procNum | Current processor number.                                                                  |
| mask    | OR'ed value of the gate index, for example: $(1 << 0) \mid (1 << 1)$ means gate 0 and gate |
|         | 1.                                                                                         |

# 17.3.10 static void SEMA4 DisableGateNotifyInterrupt ( SEMA4 Type \* base, uint8 t procNum, uint32 t mask ) [inline], [static]

Gate notification provides such feature, when core tried to lock the gate and failed, it could get notification when the gate is idle.

#### **Parameters**

| base    | SEMA4 peripheral base address.                                                                |
|---------|-----------------------------------------------------------------------------------------------|
| procNum | Current processor number.                                                                     |
| mask    | OR'ed value of the gate index, for example: $(1 << 0) \mid (1 << 1)$ means gate 0 and gate 1. |

#### 17.3.11 static uint32\_t SEMA4\_GetGateNotifyStatus ( SEMA4\_Type \* base, uint8\_t procNum ) [inline], [static]

Gate notification provides such feature, when core tried to lock the gate and failed, it could get notification when the gate is idle. The status flags are cleared automatically when the gate is locked by current core or locked again before the other core.

MCUXpresso SDK API Reference Manual

#### **Parameters**

| base    | SEMA4 peripheral base address. |
|---------|--------------------------------|
| procNum | Current processor number.      |

#### Returns

OR'ed value of the gate index, for example:  $(1 << 0) \mid (1 << 1)$  means gate 0 and gate 1 flags are pending.

# 17.3.12 status\_t SEMA4\_ResetGateNotify ( SEMA4\_Type \* base, uint8\_t gateNum )

This function resets a SEMA4 gate IRQ notification.

#### Parameters

| base    | SEMA4 peripheral base address. |
|---------|--------------------------------|
| gateNum | Gate number.                   |

#### Return values

| kStatus_Success | Reset successfully.                  |
|-----------------|--------------------------------------|
| kStatus_Fail    | Some other reset process is ongoing. |

# 17.3.13 static status\_t SEMA4\_ResetAllGateNotify ( SEMA4\_Type \* base ) [inline], [static]

This function resets all SEMA4 gate IRQ notifications.

#### **Parameters**

| base | SEMA4 peripheral base address. |
|------|--------------------------------|
|------|--------------------------------|

## Return values

| kStatus_Success | Reset successfully.                  |
|-----------------|--------------------------------------|
| kStatus_Fail    | Some other reset process is ongoing. |

MCUXpresso SDK API Reference Manual

# Chapter 18

# TMU: Thermal Management Unit Driver

## 18.1 Overview

The MCUXpresso SDK provides a peripheral driver for the thermal management unit (TMU) module of MCUXpresso SDK devices.

## 18.2 Typical use case

## **18.2.1** Monitor and report Configuration

Refer to the driver examples codes located at <SDK\_ROOT>/boards/<BOARD>/driver\_examples/tmu

## **Data Structures**

```
    struct tmu_thresold_config_t
        configuration for TMU thresold. More...
    struct tmu_interrupt_status_t
        TMU interrupt status. More...
    struct tmu_config_t
        Configuration for TMU module. More...
```

#### **Macros**

• #define FSL\_TMU\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 1))

TMU driver version.

#### **Enumerations**

**NXP Semiconductors** 

MCUXpresso SDK API Reference Manual

281

## Typical use case

```
TMU status flags.
• enum tmu_average_low_pass_filter_t {
   kTMU_AverageLowPassFilter1_0 = 0U,
   kTMU_AverageLowPassFilter0_5 = 1U,
   kTMU_AverageLowPassFilter0_25 = 2U,
   kTMU_AverageLowPassFilter0_125 = 3U }
   Average low pass filter setting.
```

## **Functions**

- void TMU\_Init (TMU\_Type \*base, const tmu\_config\_t \*config)

  Enable the access to TMU registers and Initialize TMU module.
- void TMU\_Deinit (TMU\_Type \*base)

De-initialize TMU module and Disable the access to DCDC registers.

• void TMU\_GetDefaultConfig (tmu\_config\_t \*config)

Gets the default configuration for TMU.

• static void TMU\_Enable (TMU\_Type \*base, bool enable)

Enable/Disable the TMU module.

- static void TMU\_EnableInterrupts (TMU\_Type \*base, uint32\_t mask) Enable the TMU interrupts.
- static void TMU\_DisableInterrupts (TMU\_Type \*base, uint32\_t mask)

  Disable the TMU interrupts.
- void TMU\_GetInterruptStatusFlags (TMU\_Type \*base, tmu\_interrupt\_status\_t \*status)

  Get interrupt status flags.
- void TMU\_ClearInterruptStatusFlags (TMU\_Type \*base, uint32\_t mask)

Clear interrupt status flags and corresponding interrupt critical site capture register.

• static uint32\_t TMU\_GetStatusFlags (TMU\_Type \*base)

Get TMU status flags.

• status\_t TMU\_GetHighestTemperature (TMU\_Type \*base, uint32\_t \*temperature)

Get the highest temperature reached for any enabled monitored site within the temperature sensor range.

• status\_t TMU\_GetLowestTemperature (TMU\_Type \*base, uint32\_t \*temperature)

Get the lowest temperature reached for any enabled monitored site within the temperature sensor range.

• status\_t TMU\_GetImmediateTemperature (TMU\_Type \*base, uint32\_t siteIndex, uint32\_t \*t\*temperature)

Get the last immediate temperature at site n.

- status\_t TMU\_GetAverage Temperature (TMU\_Type \*base, uint32\_t siteIndex, uint32\_t \*temperature)

  Get the last average temperature at site n.
- void TMU\_SetHighTemperatureThresold (TMU\_Type \*base, const tmu\_thresold\_config\_t \*config)

  Configure the high temperature thresold value and enable/disable relevant thresold.

## **Variables**

• bool tmu\_thresold\_config\_t::immediateThresoldEnable

Enable high temperature immediate threshold.

• bool tmu\_thresold\_config\_t::AverageThresoldEnable

Enable high temperature average threshold.

• bool tmu\_thresold\_config\_t::AverageCriticalThresoldEnable

Enable high temperature average critical threshold.

• uint8\_t tmu\_thresold\_config\_t::immediateThresoldValue Range:0U-125U.

#### **Data Structure Documentation**

• uint8\_t tmu\_thresold\_config\_t::averageThresoldValue Range:0U-125U.

• uint8\_t tmu\_thresold\_config\_t::averageCriticalThresoldValue

Range:0U-125U.

• uint32\_t tmu\_interrupt\_status\_t::interruptDetectMask

The mask of interrupt status flags.

• uint16\_t tmu\_interrupt\_status\_t::immediateInterruptsSiteMask

The mask of the temperature sensor site associated with a detected ITTE event.

• uint16\_t tmu\_interrupt\_status\_t::AverageInterruptsSiteMask

*The mask of the temperature sensor site associated with a detected ATTE event.* 

• uint16\_t tmu\_interrupt\_status\_t::AverageCriticalInterruptsSiteMask

The mask of the temperature sensor site associated with a detected ATCTE event.

uint8\_t tmu\_config\_t::monitorInterval

Temperature monitoring interval in seconds.

uint16\_t tmu\_config\_t::monitorSiteSelection

By setting the select bit for a temperature sensor site, it is enabled and included in all monitoring functions.

tmu\_average\_low\_pass\_filter\_t tmu\_config\_t::averageLPF

*The average temperature is calculated as: ALPF x Current\_Temp* + (1 - ALPF) x Average\_Temp.

#### 18.3 Data Structure Documentation

## 18.3.1 struct tmu\_thresold\_config\_t

#### **Data Fields**

• bool immediateThresoldEnable

Enable high temperature immediate threshold.

• bool AverageThresoldEnable

Enable high temperature average threshold.

bool AverageCriticalThresoldEnable

Enable high temperature average critical threshold.

• uint8 t immediateThresoldValue

Range:0U-125U.

• uint8\_t averageThresoldValue

Range:0U-125U.

• uint8\_t averageCriticalThresoldValue

Range:0U-125U.

# 18.3.2 struct tmu\_interrupt\_status\_t

#### **Data Fields**

• uint32 t interruptDetectMask

The mask of interrupt status flags.

• uint16 t immediateInterruptsSiteMask

*The mask of the temperature sensor site associated with a detected ITTE event.* 

uint16\_t AverageInterruptsSiteMask

The mask of the temperature sensor site associated with a detected ATTE event.

#### MCUXpresso SDK API Reference Manual

## **Enumeration Type Documentation**

• uint16\_t AverageCriticalInterruptsSiteMask

The mask of the temperature sensor site associated with a detected ATCTE event.

## 18.3.3 struct tmu config t

#### **Data Fields**

- uint8 t monitorInterval
  - Temperature monitoring interval in seconds.
- uint16\_t monitorSiteSelection
  - By setting the select bit for a temperature sensor site, it is enabled and included in all monitoring functions.
- tmu\_average\_low\_pass\_filter\_t averageLPF

The average temperature is calculated as:  $ALPF \times Current\_Temp + (1 - ALPF) \times Average\_Temp$ .

## 18.4 Macro Definition Documentation

## 18.4.1 #define FSL\_TMU\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 1))

Version 2.0.1.

## 18.5 Enumeration Type Documentation

## 18.5.1 enum \_tmu\_interrupt\_enable

#### Enumerator

- *kTMU\_ImmediateTemperatureInterruptEnable* Immediate temperature threshold exceeded interrupt enable.
- **kTMU\_AverageTemperatureInterruptEnable** Average temperature threshold exceeded interrupt enable.
- *kTMU\_AverageTemperatureCriticalInterruptEnable* Average temperature critical threshold exceeded interrupt enable. >

# 18.5.2 enum \_tmu\_interrupt\_status\_flags

#### Enumerator

**kTMU\_ImmediateTemperatureStatusFlags** Immediate temperature threshold exceeded(ITTE).

kTMU\_AverageTemperatureStatusFlags Average temperature threshold exceeded(ATTE).

*kTMU\_AverageTemperatureCriticalStatusFlags* Average temperature critical threshold exceeded. (ATCTE)

## 18.5.3 enum tmu status flags

#### Enumerator

- kTMU\_IntervalExceededStatusFlags Monitoring interval exceeded. The time required to perform measurement of all monitored sites has exceeded the monitoring interval as defined by TMTM-IR.
- *kTMU\_OutOfLowRangeStatusFlags* Out-of-range low temperature measurement detected. A temperature sensor detected a temperature reading below the lowest measurable temperature of 0 °C.
- *kTMU\_OutOfHighRangeStatusFlags* Out-of-range high temperature measurement detected. A temperature sensor detected a temperature reading above the highest measurable temperature of 125 °C.

## 18.5.4 enum tmu\_average\_low\_pass\_filter\_t

#### Enumerator

*kTMU\_AverageLowPassFilter1\_0* Average low pass filter = 1.

*kTMU\_AverageLowPassFilter0\_5* Average low pass filter = 0.5.

kTMU\_AverageLowPassFilter0\_25 Average low pass filter = 0.25.

*kTMU\_AverageLowPassFilter0\_125* Average low pass filter = 0.125.

## 18.6 Function Documentation

## 18.6.1 void TMU Init ( TMU Type \* base, const tmu\_config\_t \* config\_)

#### **Parameters**

| base   | TMU peripheral base address.                                           |
|--------|------------------------------------------------------------------------|
| config | Pointer to configuration structure. Refer to "tmu_config_t" structure. |

# 18.6.2 void TMU\_Deinit ( TMU\_Type \* base )

Parameters

MCUXpresso SDK API Reference Manual

| base | TMU peripheral base address. |
|------|------------------------------|
|------|------------------------------|

# 18.6.3 void TMU\_GetDefaultConfig ( tmu\_config\_t \* config )

This function initializes the user configuration structure to default value. The default value are:

## Example:

```
config->monitorInterval = 0U;
config->monitorSiteSelection = 0U;
config->averageLPF = kTMU_AverageLowPassFilter1_0;
```

#### **Parameters**

| config | Pointer to TMU configuration structure. |
|--------|-----------------------------------------|
|--------|-----------------------------------------|

# 18.6.4 static void TMU\_Enable ( TMU\_Type \* base, bool enable ) [inline], [static]

#### **Parameters**

| base   | TMU peripheral base address.    |
|--------|---------------------------------|
| enable | Switcher to enable/disable TMU. |

# 18.6.5 static void TMU\_EnableInterrupts ( TMU\_Type \* base, uint32\_t mask ) [inline], [static]

#### **Parameters**

| bas  | TMU peripheral base address.                                      |
|------|-------------------------------------------------------------------|
| mask | The interrupt mask. Refer to "_tmu_interrupt_enable" enumeration. |

# 18.6.6 static void TMU\_DisableInterrupts ( TMU\_Type \* base, uint32\_t mask ) [inline], [static]

## MCUXpresso SDK API Reference Manual

#### **Parameters**

| bas  | TMU peripheral base address.                                      |
|------|-------------------------------------------------------------------|
| mask | The interrupt mask. Refer to "_tmu_interrupt_enable" enumeration. |

# 18.6.7 void TMU\_GetInterruptStatusFlags ( TMU\_Type \* base, tmu\_interrupt\_status\_t \* status )

#### **Parameters**

| base | TMU peripheral base address.                                                                                                        |
|------|-------------------------------------------------------------------------------------------------------------------------------------|
|      | The pointer to interrupt status structure. Record the current interrupt status. Please refer to "tmu_interrupt_status_t" structure. |

# 18.6.8 void TMU\_ClearInterruptStatusFlags ( TMU\_Type \* base, uint32\_t mask )

## Parameters

| base | TMU peripheral base address.                                                        |
|------|-------------------------------------------------------------------------------------|
| The  | mask of interrupt status flags. Refer to "_tmu_interrupt_status_flags" enumeration. |

#### static uint32\_t TMU\_GetStatusFlags ( TMU\_Type \* base ) [inline], 18.6.9 [static]

#### **Parameters**

| TMU | peripheral base address. |
|-----|--------------------------|
|-----|--------------------------|

#### Returns

The mask of status flags. Refer to "\_tmu\_status\_flags" enumeration.

# 18.6.10 status t TMU GetHighestTemperature ( TMU Type \* base, uint32 t \* temperature )

**NXP Semiconductors** 

#### **Parameters**

| base        | TMU peripheral base address.                                                   |
|-------------|--------------------------------------------------------------------------------|
| temperature | Highest temperature recorded in degrees Celsius by any enabled monitored site. |

#### Returns

Execution status.

#### Return values

| kStatus_Success | Temperature reading is valid.                                                                                                      |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------|
| kStatus_Fail    | Temperature reading is not valid due to no measured temperature within the sensor range of 0-125 °C for an enabled monitored site. |

# 18.6.11 status\_t TMU\_GetLowestTemperature ( TMU\_Type \* base, uint32\_t \* temperature )

#### **Parameters**

| base        | TMU peripheral base address.                                                  |
|-------------|-------------------------------------------------------------------------------|
| temperature | Lowest temperature recorded in degrees Celsius by any enabled monitored site. |

#### Returns

Execution status.

#### Return values

| kStatus_Success | Temperature reading is valid.                                          |
|-----------------|------------------------------------------------------------------------|
| kStatus_Fail    | Temperature reading is not valid due to no measured temperature within |
|                 | the sensor range of 0-125 °C for an enabled monitored site.            |

# 18.6.12 status\_t TMU\_GetImmediateTemperature ( TMU\_Type \* base, uint32\_t siteIndex, uint32\_t \* temperature )

The site must be part of the list of enabled monitored sites as defined by monitorSiteSelection in "tmu\_config\_t" structure.

# MCUXpresso SDK API Reference Manual

289

#### **Parameters**

| base        | TMU peripheral base address.                                                 |
|-------------|------------------------------------------------------------------------------|
| siteIndex   | The index of the site user want to read. 0U: site $0 \sim 15$ U: site $15$ . |
| temperature | Last immediate temperature reading at site n.                                |

## Returns

Execution status.

## Return values

| kStatus_Fail Temperature reading is not valid because tempor first measurement still pending. | perature out of sensor range |
|-----------------------------------------------------------------------------------------------|------------------------------|

# 18.6.13 status\_t TMU\_GetAverageTemperature ( TMU\_Type \* base, uint32\_t siteIndex, uint32 t \* temperature )

The site must be part of the list of enabled monitored sites as defined by monitorSiteSelection in "tmu\_config\_t" structure.

## Parameters

| base        | TMU peripheral base address.                                                 |
|-------------|------------------------------------------------------------------------------|
| siteIndex   | The index of the site user want to read. 0U: site $0 \sim 15$ U: site $15$ . |
| temperature | Last average temperature reading at site n.                                  |

## Returns

Execution status.

#### Return values

| kStatus Success | Temperature reading is valid  |
|-----------------|-------------------------------|
| kSiaius_Success | Temperature reading is varid. |
|                 |                               |

#### Variable Documentation

| kStatus_Fail | Temperature reading is not valid because temperature out of sensor range |
|--------------|--------------------------------------------------------------------------|
|              | or first measurement still pending.                                      |

# 18.6.14 void TMU\_SetHighTemperatureThresold ( TMU\_Type \* base, const tmu\_thresold\_config\_t \* config )

#### **Parameters**

| base   | TMU peripheral base address.                                                    |
|--------|---------------------------------------------------------------------------------|
| config | Pointer to configuration structure. Refer to "tmu_thresold_config_t" structure. |

#### 18.7 Variable Documentation

- 18.7.1 bool tmu thresold config t::immediateThresoldEnable
- 18.7.2 bool tmu thresold config t::AverageThresoldEnable
- 18.7.3 bool tmu thresold config t::AverageCriticalThresoldEnable
- 18.7.4 uint8 t tmu thresold config t::immediateThresoldValue

Valid when corresponding thresold is enabled. High temperature immediate threshold value. Determines the current upper temperature threshold, for anyenabled monitored site.

## 18.7.5 uint8\_t tmu\_thresold\_config\_t::averageThresoldValue

Valid when corresponding thresold is enabled. High temperature average threshold value. Determines the average upper temperature threshold, for any enabled monitored site.

# 18.7.6 uint8\_t tmu\_thresold\_config\_t::averageCriticalThresoldValue

Valid when corresponding thresold is enabled. High temperature average critical threshold value. Determines the average upper critical temperature threshold, for any enabled monitored site.

# 18.7.7 uint32\_t tmu\_interrupt\_status\_t::interruptDetectMask

Refer to "\_tmu\_interrupt\_status\_flags" enumeration.

#### **MCUXpresso SDK API Reference Manual**

291

## 18.7.8 uint16\_t tmu\_interrupt\_status\_t::immediateInterruptsSiteMask

Please refer to "\_tmu\_monitor\_site" enumeration.

## 18.7.9 uint16\_t tmu\_interrupt\_status\_t::AverageInterruptsSiteMask

Please refer to "\_tmu\_monitor\_site" enumeration.

## 18.7.10 uint16\_t tmu\_interrupt\_status\_t::AverageCriticalInterruptsSiteMask

Please refer to "\_tmu\_monitor\_site" enumeration.

## 18.7.11 uint8\_t tmu\_config\_t::monitorInterval

Please refer to specific table in RM.

**NXP Semiconductors** 

## 18.7.12 uint16\_t tmu\_config\_t::monitorSiteSelection

If no site is selected, site 0 is monitored by default. Refer to "\_tmu\_monitor\_site" enumeration. Please look up relevant table in reference manual.

# 18.7.13 tmu\_average\_low\_pass\_filter\_t tmu\_config\_t::averageLPF

For proper operation, this field should only change when monitoring is disabled.

WicoApiesso SDR All I Reference Manual

**Variable Documentation** 

# Chapter 19

# **WDOG: Watchdog Timer Driver**

## 19.1 Overview

The MCUXpresso SDK provides a peripheral driver for the Watchdog module (WDOG) of MCUXpresso SDK devices.

## 19.2 Typical use case

Refer to the driver examples codes located at <SDK\_ROOT>/boards/<BOARD>/driver\_examples/wdog

## **Data Structures**

- struct wdog\_work\_mode\_t
   Defines WDOG work mode. More...
- struct wdog\_config\_t

Describes WDOG configuration structure. More...

#### **Enumerations**

- enum \_wdog\_interrupt\_enable { kWDOG\_InterruptEnable = WDOG\_WICR\_WIE\_MASK } WDOG interrupt configuration structure, default settings all disabled.
- enum \_wdog\_status\_flags {

```
kWDOG RunningFlag = WDOG WCR WDE MASK,
```

kWDOG\_PowerOnResetFlag = WDOG\_WRSR\_POR\_MASK,

kWDOG\_TimeoutResetFlag = WDOG\_WRSR\_TOUT\_MASK,

kWDOG SoftwareResetFlag = WDOG WRSR SFTW MASK,

kWDOG\_InterruptFlag = WDOG\_WICR\_WTIS\_MASK }

WDOG status flags.

## **Driver version**

• #define FSL\_WDOG\_DRIVER\_VERSION (MAKE\_VERSION(2, 1, 0)) Defines WDOG driver version.

## Refresh sequence

• #define **WDOG\_REFRESH\_KEY** (0xAAAA5555U)

#### WDOG Initialization and De-initialization.

- void WDOG\_GetDefaultConfig (wdog\_config\_t \*config)

  Initializes the WDOG configuration sturcture.
- void WDOG\_Init (WDOG\_Type \*base, const wdog\_config\_t \*config)

#### **Data Structure Documentation**

Initializes the WDOG.

void WDOG\_Deinit (WDOG\_Type \*base)

Shuts down the WDOG.

• static void WDOG\_Enable (WDOG\_Type \*base)

Enables the WDOG module.

• static void WDOG\_Disable (WDOG\_Type \*base)

Disables the WDOG module.

• static void WDOG\_TriggerSystemSoftwareReset (WDOG\_Type \*base)

Trigger the system software reset.

static void WDOG\_TriggerSoftwareSignal (WDOG\_Type \*base)

Trigger an output assertion.

• static void WDOG\_EnableInterrupts (WDOG\_Type \*base, uint16\_t mask)

Enables the WDOG interrupt.

• uint16\_t WDOG\_GetStatusFlags (WDOG\_Type \*base)

Gets the WDOG all reset status flags.

• void WDOG\_ClearInterruptStatus (WDOG\_Type \*base, uint16\_t mask)

Clears the WDOG flag.

• static void WDOG\_SetTimeoutValue (WDOG\_Type \*base, uint16\_t timeoutCount)

Sets the WDOG timeout value.

• static void WDOG\_SetInterrputTimeoutValue (WDOG\_Type \*base, uint16\_t timeoutCount)

Sets the WDOG interrupt count timeout value.

• static void WDOG\_DisablePowerDownEnable (WDOG\_Type \*base)

Disable the WDOG power down enable bit.

• void WDOG\_Refresh (WDOG\_Type \*base)

Refreshes the WDOG timer.

#### 19.3 Data Structure Documentation

#### 19.3.1 struct wdog work mode t

#### **Data Fields**

• bool enableWait

continue or suspend WDOG in wait mode

bool enableStop

continue or suspend WDOG in stop mode

bool enableDebug

continue or suspend WDOG in debug mode

# 19.3.2 struct wdog\_config\_t

#### **Data Fields**

bool enableWdog

Enables or disables WDOG.

wdog work mode t workMode

Configures WDOG work mode in debug stop and wait mode.

bool enableInterrupt

#### MCUXpresso SDK API Reference Manual

Enables or disables WDOG interrupt.

• uint16 t timeoutValue

Timeout value.

• uint16\_t interruptTimeValue

Interrupt count timeout value.

bool softwareResetExtension

software reset extension

• bool enablePowerDown

power down enable bit

bool enableTimeOutAssert

Enable WDOG\_B timeout assertion.

#### 19.3.2.0.0.19 Field Documentation

#### 19.3.2.0.0.19.1 bool wdog config t::enableTimeOutAssert

## 19.4 Enumeration Type Documentation

## 19.4.1 enum \_wdog\_interrupt\_enable

This structure contains the settings for all of the WDOG interrupt configurations.

## Enumerator

**kWDOG\_InterruptEnable** WDOG timeout generates an interrupt before reset.

## 19.4.2 enum wdog status flags

This structure contains the WDOG status flags for use in the WDOG functions.

#### Enumerator

**kWDOG\_RunningFlag** Running flag, set when WDOG is enabled.

kWDOG PowerOnResetFlag Power On flag, set when reset is the result of a powerOnReset.

kWDOG\_TimeoutResetFlag Timeout flag, set when reset is the result of a timeout.

**kWDOG** SoftwareResetFlag Software flag, set when reset is the result of a software.

kWDOG InterruptFlag interrupt flag, whether interrupt has occurred or not

#### 19.5 Function Documentation

# 19.5.1 void WDOG\_GetDefaultConfig ( wdog\_config\_t \* config )

This function initializes the WDOG configuration structure to default values. The default values are as follows.

\* wdogConfig->enableWdog = true;
\* wdogConfig->workMode.enableWait = true;
\* wdogConfig->workMode.enableStop = false;

## MCUXpresso SDK API Reference Manual

```
* wdogConfig->workMode.enableDebug = false;
* wdogConfig->enableInterrupt = false;
* wdogConfig->enablePowerdown = false;
* wdogConfig->resetExtension = flase;
* wdogConfig->timeoutValue = 0xFFU;
* wdogConfig->interruptTimeValue = 0x04u;
```

#### **Parameters**

| config | Pointer to the WDOG configuration structure. |
|--------|----------------------------------------------|
|--------|----------------------------------------------|

See Also

wdog\_config\_t

## 19.5.2 void WDOG\_Init ( WDOG\_Type \* base, const wdog\_config\_t \* config )

This function initializes the WDOG. When called, the WDOG runs according to the configuration.

This is an example.

```
* wdog_config_t config;

* WDOG_GetDefaultConfig(&config);

* config.timeoutValue = 0xffU;

* config->interruptTimeValue = 0x04u;

* WDOG_Init(wdog_base,&config);

*
```

#### **Parameters**

| base   | WDOG peripheral base address |
|--------|------------------------------|
| config | The configuration of WDOG    |

# 19.5.3 void WDOG\_Deinit ( WDOG\_Type \* base )

This function shuts down the WDOG. Watchdog Enable bit is a write one once only bit. It is not possible to clear this bit by a software write, once the bit is set. This bit(WDE) can be set/reset only in debug mode(exception).

# 19.5.4 static void WDOG\_Enable ( WDOG\_Type \* base ) [inline], [static]

This function writes a value into the WDOG\_WCR register to enable the WDOG. This is a write one once only bit. It is not possible to clear this bit by a software write, once the bit is set. only debug mode exception.

#### MCUXpresso SDK API Reference Manual

297

#### **Parameters**

| base | WDOG peripheral base address |
|------|------------------------------|
|------|------------------------------|

## 19.5.5 static void WDOG Disable ( WDOG Type \* base ) [inline], [static]

This function writes a value into the WDOG\_WCR register to disable the WDOG. This is a write one once only bit. It is not possible to clear this bit by a software write, once the bit is set. only debug mode exception

#### **Parameters**

| base | WDOG peripheral base address |
|------|------------------------------|
|------|------------------------------|

# 19.5.6 static void WDOG\_TriggerSystemSoftwareReset ( WDOG\_Type \* base ) [inline], [static]

This function will write to the WCR[SRS] bit to trigger a software system reset. This bit will automatically resets to "1" after it has been asserted to "0". Note: Calling this API will reset the system right now, please using it with more attention.

#### **Parameters**

| base | WDOG peripheral base address |
|------|------------------------------|
|------|------------------------------|

# 19.5.7 static void WDOG\_TriggerSoftwareSignal ( WDOG\_Type \* base ) [inline], [static]

This function will write to the WCR[WDA] bit to trigger WDOG\_B signal assertion. The WDOG\_B signal can be routed to external pin of the chip, the output pin will turn to assertion along with WDOG\_B signal. Note: The WDOG\_B signal will remain assert until a power on reset occurred, so, please take more attention while calling it.

#### **Parameters**

| base | WDOG peripheral base address |
|------|------------------------------|
|------|------------------------------|

# 19.5.8 static void WDOG\_EnableInterrupts ( WDOG\_Type \* base, uint16\_t mask ) [inline], [static]

This bit is a write once only bit. Once the software does a write access to this bit, it will get locked and cannot be reprogrammed until the next system reset assertion

#### **Parameters**

| base | WDOG peripheral base address                                                                                           |
|------|------------------------------------------------------------------------------------------------------------------------|
| mask | The interrupts to enable The parameter can be combination of the following source if defined.  • kWDOG_InterruptEnable |

## 19.5.9 uint16\_t WDOG\_GetStatusFlags ( WDOG\_Type \* base )

This function gets all reset status flags.

```
* uint16_t status;
* status = WDOG_GetStatusFlags (wdog_base);
*
```

#### **Parameters**

| base | WDOG peripheral base address |
|------|------------------------------|

## Returns

State of the status flag: asserted (true) or not-asserted (false).

#### See Also

```
_wdog_status_flags
```

- true: a related status flag has been set.
- false: a related status flag is not set.

# 19.5.10 void WDOG\_ClearInterruptStatus ( WDOG\_Type \* base, uint16\_t mask )

This function clears the WDOG status flag.

This is an example for clearing the interrupt flag.

```
* WDOG_ClearStatusFlags(wdog_base,KWDOG_InterruptFlag);
*
```

#### **Parameters**

| base | WDOG peripheral base address                                                                                 |
|------|--------------------------------------------------------------------------------------------------------------|
| mask | The status flags to clear. The parameter could be any combination of the following values. kWDOG_TimeoutFlag |

# 19.5.11 static void WDOG\_SetTimeoutValue ( WDOG\_Type \* base, uint16\_t timeoutCount ) [inline], [static]

This function sets the timeout value. This function writes a value into WCR registers. The time-out value can be written at any point of time but it is loaded to the counter at the time when WDOG is enabled or after the service routine has been performed.

#### **Parameters**

| base         | WDOG peripheral base address                  |
|--------------|-----------------------------------------------|
| timeoutCount | WDOG timeout value; count of WDOG clock tick. |

# 19.5.12 static void WDOG\_SetInterrputTimeoutValue ( WDOG\_Type \* base, uint16\_t timeoutCount ) [inline], [static]

This function sets the interrupt count timeout value. This function writes a value into WIC registers which are wirte-once. This field is write once only. Once the software does a write access to this field, it will get locked and cannot be reprogrammed until the next system reset assertion.

#### **Parameters**

| base         | WDOG peripheral base address                  |
|--------------|-----------------------------------------------|
| timeoutCount | WDOG timeout value; count of WDOG clock tick. |

# 19.5.13 static void WDOG\_DisablePowerDownEnable ( WDOG\_Type \* base ) [inline], [static]

This function disable the WDOG power down enable(PDE). This function writes a value into WMCR registers which are wirte-once. This field is write once only. Once software sets this bit it cannot be reset until the next system reset.

## Parameters

| base | WDOG peripheral base address |
|------|------------------------------|
|------|------------------------------|

# 19.5.14 void WDOG\_Refresh ( WDOG\_Type \* base )

This function feeds the WDOG. This function should be called before the WDOG timer is in timeout. Otherwise, a reset is asserted.

#### **Parameters**

| base | WDOG peripheral base address |
|------|------------------------------|
|------|------------------------------|

# Chapter 20

# **IOMUXC:** Input/Output Multiplexing Controller

## 20.1 Overview

The MCUXpresso SDK provides a peripheral driver for the Input/Output Multiplexing Controller.

The IOMUXC, working in conjunction with the IOMUX, enables the chip to share one pad for multiple signals from different peripheral interfaces.

#### **Files**

• file fsl iomuxc.h

### **Driver version**

• #define FSL\_IOMUXC\_DRIVER\_VERSION (MAKE\_VERSION(2, 0, 0)) *IOMUXC driver version 2.0.0.* 

## Pin function ID

- #define IOMUXC\_PMIC\_STBY\_REQ 0x30330014, 0x0, 0x000000000, 0x0, 0x3033027C
   The pin function ID is a tuple of <muxRegister muxmode="" inputregister="" inputdaisy="" configregister>="">
- #define IOMUXC\_PMIC\_ON\_REQ 0x30330018, 0x0, 0x00000000, 0x0, 0x30330280
- #define **IOMUXC\_ONOFF** 0x3033001C, 0x0, 0x000000000, 0x0, 0x30330284
- #define IOMUXC\_POR\_B 0x30330020, 0x0, 0x000000000, 0x0, 0x30330288
- #define **IOMUXC\_RTC\_RESET\_B** 0x30330024, 0x0, 0x00000000, 0x0, 0x3033028C
- #define IOMUXC\_GPIO1\_IO00\_GPIO1\_IO00 0x30330028, 0x0, 0x000000000, 0x0, 0x30330290
- #define IOMUXC\_GPIOT\_IO0O\_CCM\_ENET\_PHY\_REF\_CLK\_ROOT 0x30330028, 0x1, 0x000000000, 0x0, 0x30330290
- #define IOMUXC\_GPIO1\_IO00\_XTALOSC\_REF\_CLK\_32K 0x30330028, 0x5, 0x000000000, 0x0, 0x30330290
- #define IOMUXC\_GPIO1\_IO00\_CCM\_EXT\_CLK1 0x30330028, 0x6, 0x00000000, 0x0, 0x30330290
- #define IOMUXC\_GPIO1\_IO01\_GPIO1\_IO01 0x3033002C, 0x0, 0x000000000, 0x0, 0x30330294
- #define IOMUXC GPIO1 IO01 PWM1 OUT 0x3033002C, 0x1, 0x00000000, 0x0, 0x30330294
- #define IOMUXC\_GPIO1\_IO01\_XTALOSC\_REF\_CLK\_24M 0x3033002C, 0x5, 0x000000000, 0x0, 0x30330294
- #define IOMUXC\_GPIO1\_IO01\_CCM\_EXT\_CLK2 0x3033002C, 0x6, 0x00000000, 0x0, 0x303330294
- #define IOMUXC\_GPIO1\_IO02\_GPIO1\_IO02 0x30330030, 0x0, 0x000000000, 0x0, 0x30330298
- #define IOMUXC\_GPIO1\_IO02\_WDOG1\_WDOG\_B 0x30330030, 0x1, 0x000000000, 0x0, 0x30330298
- #define IOMUXC\_GPIO1\_IO02\_WDOG1\_WDOG\_ANY 0x30330030, 0x5, 0x000000000, 0x0, 0x30330298
- #define IOMUXC\_GPIO1\_IO03\_GPIO1\_IO03 0x30330034, 0x0, 0x000000000, 0x0, 0x3033029-C

#### Overview

- #define IOMUXC\_GPIO1\_IO03\_USDHC1\_VSELECT 0x30330034, 0x1, 0x00000000, 0x0, 0x3033029C
- #define IOMUXC\_GPIO1\_IO03\_SDMA1\_EXT\_EVENT0 0x30330034, 0x5, 0x00000000, 0x0, 0x3033029C
- #define IOMUXC\_GPIO1\_IO04\_GPIO1\_IO04 0x30330038, 0x0, 0x000000000, 0x0, 0x303302-A0
- #define IOMUXC\_GPIO1\_IO04\_USDHC2\_VSELECT 0x30330038, 0x1, 0x00000000, 0x0, 0x303302A0
- #define IOMUXC\_GPIO1\_IO04\_SDMA1\_EXT\_EVENT1 0x30330038, 0x5, 0x00000000, 0x0, 0x303302A0
- #define IOMUXC\_GPIO1\_IO05\_GPIO1\_IO05 0x3033003C, 0x0, 0x000000000, 0x0, 0x303302-A4
- #define IOMUXC GPIO1 IO05 M4 NMI 0x3033003C, 0x1, 0x00000000, 0x0, 0x303302A4
- #define IOMUXC\_GPIO1\_IO05\_CCM\_PMIC\_READY 0x3033003C, 0x5, 0x303304BC, 0x0, 0x303302A4
- #define IOMUXC\_GPIO1\_IO06\_GPIO1\_IO06 0x30330040, 0x0, 0x000000000, 0x0, 0x303302-A8
- #define IOMUXC\_GPIO1\_IO06\_ENET1\_MDC 0x30330040, 0x1, 0x000000000, 0x0, 0x303302-A8
- #define IOMUXC\_GPIO1\_IO06\_USDHC1\_CD\_B 0x30330040, 0x5, 0x000000000, 0x0, 0x303302A8
- #define IOMUXC\_GPIO1\_IO06\_CCM\_EXT\_CLK3 0x30330040, 0x6, 0x000000000, 0x0, 0x3033302A8
- #define IOMUXC\_GPIO1\_IO07\_GPIO1\_IO07 0x30330044, 0x0, 0x000000000, 0x0, 0x303302-AC
- #define IOMUXC\_GPIO1\_IO07\_ENET1\_MDIO 0x30330044, 0x1, 0x303304C0, 0x0, 0x303302AC
- #define IOMUXC\_GPIO1\_IO07\_USDHC1\_WP 0x30330044, 0x5, 0x000000000, 0x0, 0x303302-AC
- #define IOMUXC\_GPIO1\_IO07\_CCM\_EXT\_CLK4 0x30330044, 0x6, 0x00000000, 0x0, 0x303302AC
- #define IOMUXC\_GPIO1\_IO08\_GPIO1\_IO08 0x30330048, 0x0, 0x000000000, 0x0, 0x303302-B0
- #define IOMUXC\_GPIO1\_IO08\_ENET1\_1588\_EVENT0\_IN 0x30330048, 0x1, 0x000000000, 0x0, 0x303302B0
- #define IOMUXC\_GPIO1\_IO08\_USDHC2\_RESET\_B 0x30330048, 0x5, 0x00000000, 0x0, 0x303302B0
- #define IOMUXC\_GPIO1\_IO09\_GPIO1\_IO09 0x3033004C, 0x0, 0x000000000, 0x0, 0x303302-B4
- #define IOMUXC\_GPIO1\_IO09\_ENET1\_1588\_EVENT0\_OUT 0x3033004C, 0x1, 0x000000000, 0x0, 0x303302B4
- #define IOMUXC\_GPIO1\_IO09\_SDMA2\_EXT\_EVENT0 0x3033004C, 0x5, 0x000000000, 0x0, 0x303302B4
- #define IOMUXC\_GPIO1\_IO10\_GPIO1\_IO10 0x30330050, 0x0, 0x000000000, 0x0, 0x303302-B8
- #define IOMUXC\_GPIO1\_IO10\_USB1\_OTG\_ID 0x30330050, 0x1, 0x000000000, 0x0, 0x303302B8
- #define IOMUXC\_GPIO1\_IO11\_GPIO1\_IO11 0x30330054, 0x0, 0x000000000, 0x0, 0x303302-BC
- #define IOMUXC GPIO1 IO11 USB2 OTG ID 0x30330054, 0x1, 0x00000000, 0x0,

- 0x303302BC
- #define IOMUXC\_GPIO1\_IO11\_CCM\_PMIC\_READY 0x30330054, 0x5, 0x303304BC, 0x1, 0x303302BC
- #define IOMUXC\_GPIO1\_IO12\_GPIO1\_IO12 0x30330058, 0x0, 0x000000000, 0x0, 0x303302-C0
- #define IOMUXC\_GPIO1\_IO12\_USB1\_OTG\_PWR 0x30330058, 0x1, 0x00000000, 0x0, 0x303302C0
- #define IOMUXC\_GPIO1\_IO12\_SDMA2\_EXT\_EVENT1 0x30330058, 0x5, 0x000000000, 0x0, 0x303302C0
- #define IOMUXC\_GPIO1\_IO13\_GPIO1\_IO13 0x3033005C, 0x0, 0x000000000, 0x0, 0x303302-C4
- #define IOMUXC\_GPIO1\_IO13\_USB1\_OTG\_OC 0x3033005C, 0x1, 0x000000000, 0x0, 0x303302C4
- #define IOMUXC\_GPIO1\_IO13\_PWM2\_OUT 0x3033005C, 0x5, 0x000000000, 0x0, 0x303302-C4
- #define IOMUXC\_GPIO1\_IO14\_GPIO1\_IO14 0x30330060, 0x0, 0x000000000, 0x0, 0x303302-C8
- #define IOMUXC\_GPIO1\_IO14\_USB2\_OTG\_PWR 0x30330060, 0x1, 0x00000000, 0x0, 0x303302C8
- #define IOMUXC\_GPIO1\_IO14\_PWM3\_OUT 0x30330060, 0x5, 0x000000000, 0x0, 0x303302-C8
- #define IOMUXC\_GPIO1\_IO14\_CCM\_CLKO1 0x30330060, 0x6, 0x000000000, 0x0, 0x303302-C8
- #define IOMUXC\_GPIO1\_IO15\_GPIO1\_IO15 0x30330064, 0x0, 0x000000000, 0x0, 0x303302-CC
- #define IOMUXC\_GPIO1\_IO15\_USB2\_OTG\_OC 0x30330064, 0x1, 0x000000000, 0x0, 0x303302CC
- #define IOMUXC\_GPIO1\_IO15\_PWM4\_OUT 0x30330064, 0x5, 0x00000000, 0x0, 0x303302-
- #define IOMUXC\_GPIO1\_IO15\_CCM\_CLKO2 0x30330064, 0x6, 0x000000000, 0x0, 0x303302-CC
- #define IOMUXC\_ENET\_MDC\_ENET1\_MDC 0x30330068, 0x0, 0x000000000, 0x0, 0x303302-D0
- #define **IOMUXC\_ENET\_MDC\_GPIO1\_IO16** 0x30330068, 0x5, 0x000000000, 0x0, 0x303302-
- #define **IOMUXC\_ENET\_MDIO\_ENET1\_MDIO** 0x3033006C, 0x0, 0x303304C0, 0x1, 0x303302D4
- #define IOMUXC\_ENET\_MDIO\_GPIO1\_IO17 0x3033006C, 0x5, 0x000000000, 0x0, 0x303302-D4
- #define IOMUXC\_ENET\_TD3\_ENET1\_RGMII\_TD3 0x30330070, 0x0, 0x000000000, 0x0, 0x3033302D8
- #define IOMUXC\_ENET\_TD3\_GPIO1\_IO18 0x30330070, 0x5, 0x000000000, 0x0, 0x303302D8
- #define IOMUXC\_ENET\_TD2\_ENET1\_RGMII\_TD2 0x30330074, 0x0, 0x000000000, 0x0, 0x303302DC
- #define IOMUXC\_ENET\_TD2\_ENET1\_TX\_CLK 0x30330074, 0x1, 0x00000000, 0x0, 0x303302DC
- #define IOMUXC\_ENET\_TD2\_GPIO1\_IO19 0x30330074, 0x5, 0x00000000, 0x0, 0x303302DC
- #define IOMUXC\_ENET\_TD1\_ENET1\_RGMII\_TD1 0x30330078, 0x0, 0x000000000, 0x0, 0x303302E0
- #define IOMUXC\_ENET\_TD1\_GPIO1\_IO20 0x30330078, 0x5, 0x00000000, 0x0, 0x303302E0

#### Overview

- #define **IOMUXC\_ENET\_TD0\_ENET1\_RGMII\_TD0** 0x3033007C, 0x0, 0x000000000, 0x0, 0x303302E4
- #define IOMUXC\_ENET\_TD0\_GPIO1\_IO21 0x3033007C, 0x5, 0x00000000, 0x0, 0x303302E4
- #define IOMUXC\_ENET\_TX\_CTL\_ENET1\_RGMII\_TX\_CTL 0x30330080, 0x0, 0x000000000, 0x0, 0x303302E8
- #define IOMUXC\_ENET\_TX\_CTL\_GPIO1\_IO22 0x30330080, 0x5, 0x000000000, 0x0, 0x303302E8
- #define IOMUXC\_ENET\_TXC\_ENET1\_RGMII\_TXC 0x30330084, 0x0, 0x000000000, 0x0, 0x3033302EC
- #define IOMUXC\_ENET\_TXC\_ENET1\_TX\_ER 0x30330084, 0x1, 0x00000000, 0x0, 0x303302EC
- #define IOMUXC\_ENET\_TXC\_GPIO1\_IO23 0x30330084, 0x5, 0x00000000, 0x0, 0x303302E-
- #define IOMUXC\_ENET\_RX\_CTL\_ENET1\_RGMII\_RX\_CTL 0x30330088, 0x0, 0x000000000, 0x0, 0x303302F0
- #define IOMUXC\_ENET\_RX\_CTL\_GPIO1\_IO24 0x30330088, 0x5, 0x00000000, 0x0, 0x303302F0
- #define IOMUXC\_ENET\_RXC\_ENET1\_RGMII\_RXC 0x3033008C, 0x0, 0x00000000, 0x0, 0x303302F4
- #define IOMUXC\_ENET\_RXC\_ENET1\_RX\_ER 0x3033008C, 0x1, 0x00000000, 0x0, 0x303302F4
- #define IOMUXC\_ENET\_RXC\_GPIO1\_IO25 0x3033008C, 0x5, 0x00000000, 0x0, 0x303302-F4
- #define IOMUXC\_ENET\_RD0\_ENET1\_RGMII\_RD0 0x30330090, 0x0, 0x000000000, 0x0, 0x303302F8
- #define IOMUXC\_ENET\_RD0\_GPIO1\_IO26 0x30330090, 0x5, 0x000000000, 0x0, 0x303302F8
- #define IOMUXC\_ENET\_RD1\_ENET1\_RGMII\_RD1 0x30330094, 0x0, 0x000000000, 0x0, 0x303302FC
- #define IOMUXC\_ENET\_RD1\_GPIO1\_IO27 0x30330094, 0x5, 0x00000000, 0x0, 0x303302FC
- #define IOMUXC\_ENET\_RD2\_ENET1\_RGMII\_RD2 0x30330098, 0x0, 0x000000000, 0x0, 0x30330300
- #define IOMUXC\_ENET\_RD2\_GPIO1\_IO28 0x30330098, 0x5, 0x00000000, 0x0, 0x30330300
- #define IOMUXC\_ENET\_RD3\_ENET1\_RGMII\_RD3 0x3033009C, 0x0, 0x000000000, 0x0, 0x30330304
- #define IOMUXC ENET RD3 GPIO1 IO29 0x3033009C, 0x5, 0x000000000, 0x0, 0x30330304
- #define IOMUXC\_SD1\_CLK\_USDHC1\_CLK 0x303300A0, 0x0, 0x000000000, 0x0, 0x30330308
- #define IOMUXC SD1 CLK GPIO2 IO00 0x303300A0, 0x5, 0x00000000, 0x0, 0x30330308
- #define IOMUXC\_SD1\_CMD\_USDHC1\_CMD 0x303300A4, 0x0, 0x000000000, 0x0, 0x3033030-C
- #define **IOMUXC SD1 CMD GPIO2 IO01** 0x303300A4, 0x5, 0x00000000, 0x0, 0x3033030C
- #define IOMUXC\_SDI\_DATA0\_USDHC1\_DATA0 0x303300A8, 0x0, 0x000000000, 0x0, 0x30330310
- #define IOMUXC\_SD1\_DATA0\_GPIO2\_IO02 0x303300A8, 0x5, 0x000000000, 0x0, 0x30330310
- #define IOMUXC\_SD1\_DATA1\_USDHC1\_DATA1 0x303300AC, 0x0, 0x000000000, 0x0, 0x30330314
- #define IOMUXC\_SD1\_DATA1\_GPIO2\_IO03 0x303300AC, 0x5, 0x000000000, 0x0, 0x30330314
- #define IOMUXC\_SDI\_DATA2\_USDHC1\_DATA2 0x303300B0, 0x0, 0x000000000, 0x0, 0x30330318
- #define IOMUXC SD1 DATA2 GPIO2 IO04 0x303300B0, 0x5, 0x000000000, 0x0, 0x30330318
- #define IOMUXC\_SDT\_DATA3\_USDHC1\_DATA3 0x303300B4, 0x0, 0x000000000, 0x0, 0x30333031C

- #define IOMUXC SD1 DATA3 GPIO2 IO05 0x303300B4, 0x5, 0x000000000, 0x0, 0x3033031-
- #define IOMUXC\_SD1\_DATA4\_USDHC1\_DATA4 0x303300B8, 0x0, 0x000000000, 0x0, 0x30330320
- #define IOMUXC SD1 DATA4 GPIO2 IO06 0x303300B8, 0x5, 0x00000000, 0x0, 0x30330320
- #define IOMUXC SD1 DATA5 USDHC1 DATA5 0x303300BC, 0x0, 0x000000000, 0x0,
- #define IOMUXC SD1 DATA5 GPIO2 IO07 0x303300BC, 0x5, 0x000000000, 0x0, 0x30330324
- #define IOMUXC SDI DATA6 USDHC1 DATA6 0x303300C0, 0x0, 0x000000000, 0x0,
- #define IOMUXC SD1 DATA6 GPIO2 IO08 0x303300C0, 0x5, 0x000000000, 0x0, 0x30330328
- #define IOMUXC SD1 DATA7 USDHC1 DATA7 0x303300C4, 0x0, 0x000000000, 0x0, 0x3033032C
- #define IOMUXC SD1 DATA7 GPIO2 IO09 0x303300C4, 0x5, 0x000000000, 0x0, 0x3033032-
- #define IOMUXC SD1 RESET B USDHC1 RESET B 0x303300C8, 0x0, 0x000000000, 0x0,
- #define IOMUXC SD1 RESET B GPIO2 IO10 0x303300C8, 0x5, 0x000000000. 0x0.0x30330330
- #define IOMUXC SD1 STROBE USDHC1 STROBE 0x303300CC, 0x0, 0x000000000, 0x0, 0x30330334
- #define IOMUXC\_SD1\_STROBE\_GPIO2\_IO11 0x303300CC, 0x5, 0x00000000, 0x00x30330334
- #define IOMUXC SD2 CD B USDHC2 CD B 0x303300D0, 0x0. 0x00000000. 0x0.0x30330338
- #define IOMUXC SD2 CD B GPIO2 IO12 0x303300D0, 0x5, 0x000000000, 0x0, 0x30330338
- #define IOMUXC SD2 CLK USDHC2 CLK 0x303300D4, 0x0, 0x000000000, 0x0, 0x3033033-
- #define IOMUXC\_SD2\_CLK\_GPIO2\_IO13 0x303300D4, 0x5, 0x000000000, 0x0, 0x3033033C
- #define **IOMUXC\_SD2\_CMD\_USDHC2\_CMD** 0x303300D8, 0x0, 0x00000000, 0x0, 0x30330340
- #define IOMUXC SD2 CMD GPIO2 IO14 0x303300D8, 0x5, 0x000000000, 0x0, 0x30330340
- #define IOMUXC SD2 DATA0 USDHC2 DATA0 0x303300DC, 0x0, 0x000000000, 0x0, 0x30330344
- #define **IOMUXC SD2 DATA0 GPIO2 IO15** 0x303300DC, 0x5, 0x00000000, 0x0, 0x30330344
- #define IOMUXC SD2 DATA1 USDHC2 DATA1 0x303300E0, 0x0, 0x000000000, 0x0, 0x30330348
- #define IOMUXC\_SD2\_DATA1\_GPIO2\_IO16 0x303300E0, 0x5, 0x000000000, 0x0, 0x30330348
- #define IOMUXC SD2 DATA2 USDHC2 DATA2 0x303300E4, 0x0, 0x000000000, 0x0, 0x3033034C
- #define IOMUXC SD2 DATA2 GPIO2 IO17 0x303300E4, 0x5, 0x000000000, 0x0, 0x3033034-
- #define IOMUXC SD2 DATA3 USDHC2 DATA3 0x303300E8. 0x0. 0x000000000. 0x0. 0x30330350
- #define IOMUXC\_SD2\_DATA3\_GPIO2\_IO18 0x303300E8, 0x5, 0x000000000, 0x0, 0x30330350
- #define IOMUXC SD2 RESET B USDHC2 RESET B 0x303300EC, 0x0, 0x000000000, 0x0, 0x30330354
- #define IOMUXC\_SD2\_RESET\_B\_GPIO2\_IO19 0x303300EC, 0x5, 0x000000000, 0x0,
- #define IOMUXC\_SD2\_WP\_USDHC2\_WP 0x303300F0, 0x0, 0x000000000, 0x0, 0x30330358
   #define IOMUXC\_SD2\_WP\_GPIO2\_IO20 0x303300F0, 0x5, 0x000000000, 0x0, 0x30330358
- #define IOMUXC\_NAND\_ALE\_RAWNAND\_ALE 0x303300F4, 0x0, 0x000000000, 0x0,

MCUXpresso SDK API Reference Manual

#### Overview

- 0x3033035C
- #define IOMUXC\_NAND\_ALE\_QSPI\_A\_SCLK 0x303300F4, 0x1, 0x000000000, 0x0, 0x3033035C
- #define IOMUXC\_NAND\_ALE\_GPIO3\_IO00 0x303300F4, 0x5, 0x000000000, 0x0, 0x3033035-
- #define IOMUXC\_NAND\_CE0\_B\_RAWNAND\_CE0\_B 0x303300F8, 0x0, 0x000000000, 0x0, 0x30330360
- #define IOMUXC\_NAND\_CE0\_B\_QSPI\_A\_SS0\_B 0x303300F8, 0x1, 0x00000000, 0x0, 0x30330360
- #define IOMUXC\_NAND\_CE0\_B\_GPIO3\_IO01 0x303300F8, 0x5, 0x00000000, 0x0, 0x30330360
- #define IOMUXC\_NAND\_CE1\_B\_RAWNAND\_CE1\_B 0x303300FC, 0x0, 0x000000000, 0x0, 0x30330364
- #define IOMUXC\_NAND\_CE1\_B\_QSPI\_A\_SS1\_B 0x303300FC, 0x1, 0x00000000, 0x0, 0x30330364
- #define IOMUXC\_NAND\_CE1\_B\_GPIO3\_IO02 0x303300FC, 0x5, 0x00000000, 0x0, 0x30330364
- #define IOMUXC\_NAND\_CE2\_B\_RAWNAND\_CE2\_B 0x30330100, 0x0, 0x000000000, 0x0, 0x30330368
- #define IOMUXC\_NAND\_CE2\_B\_QSPI\_B\_SS0\_B 0x30330100, 0x1, 0x000000000, 0x0, 0x30330368
- #define IOMUXC\_NAND\_CE2\_B\_GPIO3\_IO03 0x30330100, 0x5, 0x000000000, 0x0, 0x30330368
- #define IOMUXC\_NAND\_CE3\_B\_RAWNAND\_CE3\_B 0x30330104, 0x0, 0x000000000, 0x0, 0x3033036C
- #define IOMUXC\_NAND\_CE3\_B\_QSPI\_B\_SS1\_B 0x30330104, 0x1, 0x00000000, 0x0, 0x3033036C
- #define IOMUXC\_NAND\_CE3\_B\_GPIO3\_IO04 0x30330104, 0x5, 0x00000000, 0x0, 0x3033036C
- #define IOMUXC\_NAND\_CLE\_RAWNAND\_CLE 0x30330108, 0x0, 0x000000000, 0x0, 0x30330370
- #define IOMUXC\_NAND\_CLE\_QSPI\_B\_SCLK 0x30330108, 0x1, 0x000000000, 0x0, 0x30330370
- #define IOMUXC\_NAND\_CLE\_GPIO3\_IO05 0x30330108, 0x5, 0x000000000, 0x0, 0x30330370
- #define IOMUXC\_NAND\_DATA00\_RAWNAND\_DATA00\_0x3033010C, 0x0, 0x000000000, 0x0, 0x30330374
- #define IOMUXC\_NAND\_DATA00\_QSPI\_A\_DATA0 0x3033010C, 0x1, 0x000000000, 0x0, 0x30330374
- #define IOMUXC\_NAND\_DATA00\_GPIO3\_IO06 0x3033010C, 0x5, 0x000000000, 0x0, 0x30330374
- #define IOMUXC\_NAND\_DATA01\_RAWNAND\_DATA01 0x30330110, 0x0, 0x000000000, 0x0, 0x30330378
- #define IOMUXC\_NAND\_DATA01\_QSPI\_A\_DATA1 0x30330110, 0x1, 0x00000000, 0x0, 0x30330378
- #define IOMUXC\_NAND\_DATA01\_GPIO3\_IO07 0x30330110, 0x5, 0x000000000, 0x0, 0x30330378
- #define IOMUXC\_NAND\_DATA02\_RAWNAND\_DATA02 0x30330114, 0x0, 0x000000000, 0x0, 0x3033037C
- #define IOMUXC\_NAND\_DATA02\_QSPI\_A\_DATA2 0x30330114, 0x1, 0x00000000, 0x0, 0x3033037C

309

- #define IOMUXC\_NAND\_DATA02\_GPIO3\_IO08 0x30330114, 0x5, 0x00000000, 0x0, 0x3033037C
- #define IOMUXC\_NAND\_DATA03\_RAWNAND\_DATA03 0x30330118, 0x0, 0x000000000, 0x0, 0x30330380
- #define IOMUXC\_NAND\_DATA03\_QSPI\_A\_DATA3 0x30330118, 0x1, 0x00000000, 0x0, 0x30330380
- #define IOMUXC\_NAND\_DATA03\_GPIO3\_IO09 0x30330118, 0x5, 0x000000000, 0x0, 0x30330380
- #define IOMUXC\_NAND\_DATA04\_RAWNAND\_DATA04 0x3033011C, 0x0, 0x000000000, 0x0, 0x30330384
- #define IOMUXC\_NAND\_DATA04\_QSPI\_B\_DATA0 0x3033011C, 0x1, 0x000000000, 0x0, 0x30330384
- #define IOMUXC\_NAND\_DATA04\_GPIO3\_IO10 0x3033011C, 0x5, 0x000000000, 0x0, 0x30330384
- #define IOMUXC\_NAND\_DATA05\_RAWNAND\_DATA05 0x30330120, 0x0, 0x000000000, 0x0, 0x30330388
- #define IOMUXC\_NAND\_DATA05\_QSPI\_B\_DATA1 0x30330120, 0x1, 0x00000000, 0x0, 0x30330388
- #define IOMUXC\_NAND\_DATA05\_GPIO3\_IO11 0x30330120, 0x5, 0x000000000, 0x0, 0x30330388
- #define IOMUXC\_NAND\_DATA06\_RAWNAND\_DATA06 0x30330124, 0x0, 0x000000000, 0x0, 0x3033038C
- #define IOMUXC\_NAND\_DATA06\_QSPI\_B\_DATA2 0x30330124, 0x1, 0x00000000, 0x0, 0x3033038C
- #define IOMUXC\_NAND\_DATA06\_GPIO3\_IO12 0x30330124, 0x5, 0x00000000, 0x0, 0x3033038C
- #define IOMUXC\_NAND\_DATA07\_RAWNAND\_DATA07 0x30330128, 0x0, 0x000000000, 0x0, 0x30330390
- #define IOMUXC\_NAND\_DATA07\_QSPI\_B\_DATA3 0x30330128, 0x1, 0x00000000, 0x0, 0x30330390
- #define IOMUXC\_NAND\_DATA07\_GPIO3\_IO13 0x30330128, 0x5, 0x000000000, 0x0, 0x30330390
- #define IOMUXC\_NAND\_DQS\_RAWNAND\_DQS 0x3033012C, 0x0, 0x000000000, 0x0, 0x30330394
- #define **IOMUXC NAND DOS QSPI A DOS** 0x3033012C, 0x1, 0x00000000, 0x0, 0x30330394
- #define **IOMUXC NAND DOS GPIO3 IO14** 0x3033012C, 0x5, 0x000000000, 0x0, 0x30330394
- #define IOMUXC\_NAND\_RE\_B\_RAWNAND\_RE\_B 0x30330130, 0x0, 0x000000000, 0x0, 0x30330398
- #define IOMUXC NAND RE B OSPI B DOS 0x30330130, 0x1, 0x00000000, 0x0, 0x30330398
- #define IOMUXC\_NAND\_RE\_B\_GPIO3\_IO15 0x30330130, 0x5, 0x000000000, 0x0, 0x30330398
- #define IOMUXC\_NAND\_READY\_B\_RAWNAND\_READY\_B 0x30330134, 0x0, 0x000000000, 0x0, 0x3033039C
- #define IOMUXC\_NAND\_READY\_B\_GPIO3\_IO16 0x30330134, 0x5, 0x00000000, 0x0, 0x3033039C
- #define IOMUXC\_NAND\_WE\_B\_RAWNAND\_WE\_B 0x30330138, 0x0, 0x000000000, 0x0, 0x303303A0
- #define IOMUXC\_NAND\_WE\_B\_GPIO3\_IO17 0x30330138, 0x5, 0x000000000, 0x0, 0x303303-A0
- #define IOMUXC\_NAND\_WP\_B\_RAWNAND\_WP\_B 0x3033013C, 0x0, 0x000000000, 0x0, 0x303303A4

#### Overview

- #define IOMUXC\_NAND\_WP\_B\_GPIO3\_IO18 0x3033013C, 0x5, 0x000000000, 0x0, 0x303303-A4
- #define IOMUXC\_SAI5\_RXFS\_SAI5\_RX\_SYNC 0x30330140, 0x0, 0x303304E4, 0x0, 0x303303A8
- #define IOMUXC\_SAI5\_RXFS\_SAI1\_TX\_DATA0 0x30330140, 0x1, 0x00000000, 0x0, 0x303303A8
- #define IOMUXC\_SAI5\_RXFS\_GPIO3\_IO19 0x30330140, 0x5, 0x00000000, 0x0, 0x303303A8
- #define IOMUXC\_SAI5\_RXC\_SAI5\_RX\_BCLK 0x30330144, 0x0, 0x303304D0, 0x0, 0x303303AC
- #define IOMUXC\_SAI5\_RXC\_SAI1\_TX\_DATA1 0x30330144, 0x1, 0x00000000, 0x0, 0x303303AC
- #define IOMUXC\_SAI5\_RXC\_GPIO3\_IO20 0x30330144, 0x5, 0x00000000, 0x0, 0x303303AC
- #define IOMUXC\_SAI5\_RXD0\_SAI5\_RX\_DATA0 0x30330148, 0x0, 0x303304D4, 0x0, 0x303303B0
- #define IOMUXC\_SAI5\_RXD0\_SAI1\_TX\_DATA2 0x30330148, 0x1, 0x00000000, 0x0, 0x303303B0
- #define IOMUXC\_SAI5\_RXD0\_GPIO3\_IO21 0x30330148, 0x5, 0x000000000, 0x0, 0x303303B0
- #define IOMUXC\_SAI5\_RXD1\_SAI5\_RX\_DATA1 0x3033014C, 0x0, 0x303304D8, 0x0, 0x303303B4
- #define IOMUXC\_SAI5\_RXD1\_SAI1\_TX\_DATA3 0x3033014C, 0x1, 0x00000000, 0x0, 0x303303B4
- #define IOMUXC\_SAI5\_RXD1\_SAI1\_TX\_SYNC 0x3033014C, 0x2, 0x303304CC, 0x0, 0x303303B4
- #define IOMUXC\_SAI5\_RXD1\_SAI5\_TX\_SYNC 0x3033014C, 0x3, 0x303304EC, 0x0, 0x303303B4
- #define IOMUXC\_SAI5\_RXD1\_GPIO3\_IO22 0x3033014C, 0x5, 0x000000000, 0x0, 0x303303-B4
- #define IOMUXC\_SAI5\_RXD2\_SAI5\_RX\_DATA2 0x30330150, 0x0, 0x303304DC, 0x0, 0x303303B8
- #define IOMUXC\_SAI5\_RXD2\_SAI1\_TX\_DATA4 0x30330150, 0x1, 0x000000000, 0x0, 0x303303B8
- #define IOMUXC\_SAI5\_RXD2\_SAI1\_TX\_SYNC 0x30330150, 0x2, 0x303304CC, 0x1, 0x303303B8
- #define IOMUXC\_SAI5\_RXD2\_SAI5\_TX\_BCLK 0x30330150, 0x3, 0x303304E8, 0x0, 0x303303B8
- #define IOMUXC\_SAI5\_RXD2\_GPIO3\_IO23 0x30330150, 0x5, 0x000000000, 0x0, 0x303303B8
- #define IOMUXC\_SAI5\_RXD3\_SAI5\_RX\_DATA3 0x30330154, 0x0, 0x303304E0, 0x0, 0x303303BC
- #define IOMUXC\_SAI5\_RXD3\_SAI1\_TX\_DATA5 0x30330154, 0x1, 0x00000000, 0x0, 0x303303BC
- #define IOMUXC\_SAI5\_RXD3\_SAI1\_TX\_SYNC 0x30330154, 0x2, 0x303304CC, 0x2, 0x303303BC
- #define IOMUXC\_SAI5\_RXD3\_SAI5\_TX\_DATA0 0x30330154, 0x3, 0x00000000, 0x0, 0x303303BC
- #define IOMUXC\_SAI5\_RXD3\_GPIO3\_IO24 0x30330154, 0x5, 0x000000000, 0x0, 0x303303B-C
- #define IOMUXC\_SAI5\_MCLK\_SAI5\_MCLK 0x30330158, 0x0, 0x3033052C, 0x0, 0x303303-C0
- #define IOMUXC\_SAI5\_MCLK\_SAI1\_TX\_BCLK 0x30330158, 0x1, 0x303304C8, 0x0, 0x303303C0

- #define IOMUXC\_SAI5\_MCLK\_SAI4\_MCLK 0x30330158, 0x2, 0x00000000, 0x0, 0x303303-C0
- #define IOMUXC\_SAI5\_MCLK\_GPIO3\_IO25 0x30330158, 0x5, 0x000000000, 0x0, 0x303303-C0
- #define IOMUXC\_SAI1\_RXFS\_SAI1\_RX\_SYNC 0x3033015C, 0x0, 0x303304C4, 0x0, 0x303303C4
- #define IOMUXC\_SAI1\_RXFS\_SAI5\_RX\_SYNC 0x3033015C, 0x1, 0x303304E4, 0x1 0x303303C4
- #define IOMUXC\_SAI1\_RXFS\_CORESIGHT\_TRACE\_CLK 0x3033015C, 0x4, 0x00000000, 0x0, 0x303303C4
- #define IOMUXC\_SAI1\_RXFS\_GPIO4\_IO00 0x3033015C, 0x5, 0x000000000, 0x0, 0x303303-C4
- #define IOMUXC\_SAI1\_RXC\_SAI1\_RX\_BCLK 0x30330160, 0x0, 0x000000000, 0x0, 0x303303C8
- #define IOMUXC\_SAI1\_RXC\_SAI5\_RX\_BCLK 0x30330160, 0x1, 0x303304D0, 0x1, 0x303303C8
- #define IOMUXC\_SAI1\_RXC\_CORESIGHT\_TRACE\_CTL 0x30330160, 0x4, 0x000000000, 0x0, 0x303303C8
- #define IOMUXC\_SAI1\_RXC\_GPIO4\_IO01 0x30330160, 0x5, 0x00000000, 0x0, 0x303303C8
- #define IOMUXC\_SAI1\_RXD0\_SAI1\_RX\_DATA0 0x30330164, 0x0, 0x00000000, 0x0, 0x303303CC
- #define IOMUXC\_SAI1\_RXD0\_SAI5\_RX\_DATA0 0x30330164, 0x1, 0x303304D4, 0x1, 0x303303CC
- #define IOMUXC\_SAI1\_RXD0\_CORESIGHT\_TRACE0 0x30330164, 0x4, 0x00000000, 0x0, 0x303303CC
- #define IOMUXC\_SAI1\_RXD0\_GPIO4\_IO02 0x30330164, 0x5, 0x000000000, 0x0, 0x303303C-C
- #define IOMUXC\_SAI1\_RXD0\_SRC\_BOOT\_CFG0 0x30330164, 0x6, 0x00000000, 0x0, 0x303303CC
- #define IOMUXC\_SAI1\_RXD1\_SAI1\_RX\_DATA1 0x30330168, 0x0, 0x000000000, 0x0, 0x303303D0
- #define IOMUXC\_SAI1\_RXD1\_SAI5\_RX\_DATA1 0x30330168, 0x1, 0x303304D8, 0x1, 0x303303D0
- #define IOMUXC\_SAI1\_RXD1\_CORESIGHT\_TRACE1 0x30330168, 0x4, 0x00000000, 0x0, 0x303303D0
- #define IOMUXC SAI1 RXD1 GPIO4 IO03 0x30330168, 0x5, 0x000000000, 0x0, 0x303303D0
- #define IOMUXC\_SAI1\_RXD1\_SRC\_BOOT\_CFG1 0x30330168, 0x6, 0x000000000, 0x0, 0x303303D0
- #define IOMUXC\_SAI1\_RXD2\_SAI1\_RX\_DATA2 0x3033016C, 0x0, 0x000000000, 0x0, 0x303303D4
- #define IOMUXC\_SAI1\_RXD2\_SAI5\_RX\_DATA2 0x3033016C, 0x1, 0x303304DC, 0x1, 0x303303D4
- #define IOMUXC\_SAI1\_RXD2\_CORESIGHT\_TRACE2 0x3033016C, 0x4, 0x00000000, 0x0, 0x303303D4
- #define IOMUXC\_SAI1\_RXD2\_GPIO4\_IO04 0x3033016C, 0x5, 0x000000000, 0x0, 0x303303-D4
- #define IOMUXC\_SAI1\_RXD2\_SRC\_BOOT\_CFG2 0x3033016C, 0x6, 0x000000000, 0x0, 0x303303D4
- #define IOMUXC\_SAI1\_RXD3\_SAI1\_RX\_DATA3 0x30330170, 0x0, 0x000000000, 0x0, 0x303303D8

#### Overview

- #define IOMUXC\_SAI1\_RXD3\_SAI5\_RX\_DATA3 0x30330170, 0x1, 0x303304E0, 0x1, 0x303303D8
- #define IOMUXC\_SAI1\_RXD3\_CORESIGHT\_TRACE3 0x30330170, 0x4, 0x00000000, 0x0, 0x303303D8
- #define IOMUXC\_SAI1\_RXD3\_GPIO4\_IO05 0x30330170, 0x5, 0x000000000, 0x0, 0x303303D8
- #define IOMUXC\_SAIT\_RXD3\_SRC\_BOOT\_CFG3 0x30330170, 0x6, 0x00000000, 0x0, 0x303303D8
- #define IOMUXC\_SAI1\_RXD4\_SAI1\_RX\_DATA4 0x30330174, 0x0, 0x00000000, 0x0, 0x303303DC
- #define IOMUXC\_SAI1\_RXD4\_SAI6\_TX\_BCLK 0x30330174, 0x1, 0x3033051C, 0x0, 0x303303DC
- #define IOMUXC\_SAI1\_RXD4\_SAI6\_RX\_BCLK 0x30330174, 0x2, 0x30330510, 0x0, 0x303303DC
- #define IOMUXC\_SAI1\_RXD4\_CORESIGHT\_TRACE4 0x30330174, 0x4, 0x00000000, 0x0, 0x303303DC
- #define IOMUXC\_SAI1\_RXD4\_GPIO4\_IO06 0x30330174, 0x5, 0x000000000, 0x0, 0x303303D-C
- #define IOMUXC\_SAI1\_RXD4\_SRC\_BOOT\_CFG4 0x30330174, 0x6, 0x00000000, 0x0, 0x303303DC
- #define IOMUXC\_SAI1\_RXD5\_SAI1\_RX\_DATA5 0x30330178, 0x0, 0x00000000, 0x0, 0x303303E0
- #define IOMUXC\_SAI1\_RXD5\_SAI6\_TX\_DATA0 0x30330178, 0x1, 0x00000000, 0x0, 0x303303E0
- #define IOMUXC\_SAI1\_RXD5\_SAI6\_RX\_DATA0 0x30330178, 0x2, 0x30330514, 0x0, 0x303303E0
- #define IOMUXC\_SAI1\_RXD5\_SAI1\_RX\_SYNC 0x30330178, 0x3, 0x303304C4, 0x1, 0x303303E0
- #define IOMUXC\_SAI1\_RXD5\_CORESIGHT\_TRACE5 0x30330178, 0x4, 0x000000000, 0x0, 0x303303F0
- #define IOMUXC\_SAI1\_RXD5\_GPIO4\_IO07 0x30330178, 0x5, 0x000000000, 0x0, 0x303303E0
- #define IOMUXC\_SAIT\_RXD5\_SRC\_BOOT\_CFG5 0x30330178, 0x6, 0x000000000, 0x0, 0x303303E0
- #define IOMUXC\_SAI1\_RXD6\_SAI1\_RX\_DATA6 0x3033017C, 0x0, 0x000000000, 0x0, 0x303303E4
- #define IOMUXC\_SAI1\_RXD6\_SAI6\_TX\_SYNC 0x3033017C, 0x1, 0x30330520, 0x0, 0x303303E4
- #define IOMUXC\_SAI1\_RXD6\_SAI6\_RX\_SYNC 0x3033017C, 0x2, 0x30330518, 0x0, 0x303303E4
- #define IOMUXC\_SAI1\_RXD6\_CORESIGHT\_TRACE6 0x3033017C, 0x4, 0x00000000, 0x0, 0x303303E4
- #define IOMUXC\_SAI1\_RXD6\_GPIO4\_IO08 0x3033017C, 0x5, 0x000000000, 0x0, 0x303303-F4
- #define IOMUXC\_SAI1\_RXD6\_SRC\_BOOT\_CFG6 0x3033017C, 0x6, 0x000000000, 0x0, 0x303303E4
- #define IOMUXC\_SAI1\_RXD7\_SAI1\_RX\_DATA7 0x30330180, 0x0, 0x000000000, 0x0, 0x303303E8
- #define IOMUXC\_SAI1\_RXD7\_SAI6\_MCLK 0x30330180, 0x1, 0x30330530, 0x0, 0x303303E8
- #define IOMUXC\_SAII\_RXD7\_SAII\_TX\_SYNC 0x30330180, 0x2, 0x303304CC, 0x4, 0x303303F8
- #define IOMUXC\_SAI1\_RXD7\_SAI1\_TX\_DATA4 0x30330180, 0x3, 0x000000000, 0x0,

- 0x303303E8
- #define IOMUXC\_SAI1\_RXD7\_CORESIGHT\_TRACE7 0x30330180, 0x4, 0x00000000, 0x0, 0x303303E8
- #define IOMUXC\_SAI1\_RXD7\_GPIO4\_IO09 0x30330180, 0x5, 0x000000000, 0x0, 0x303303E8
- #define IOMUXC\_SAII\_RXD7\_SRC\_BOOT\_CFG7 0x30330180, 0x6, 0x000000000, 0x0, 0x303303E8
- #define IOMUXC\_SAI1\_TXFS\_SAI1\_TX\_SYNC 0x30330184, 0x0, 0x303304CC, 0x3, 0x303303EC
- #define IOMUXC\_SAI1\_TXFS\_SAI5\_TX\_SYNC 0x30330184, 0x1, 0x303304EC, 0x1, 0x303303EC
- #define IOMUXC\_SAI1\_TXFS\_CORESIGHT\_EVENTO 0x30330184, 0x4, 0x00000000, 0x0, 0x303303EC
- #define IOMUXC\_SAI1\_TXFS\_GPIO4\_IO10 0x30330184, 0x5, 0x000000000, 0x0, 0x303303EC
- #define IOMUXC\_SAI1\_TXC\_SAI1\_TX\_BCLK 0x30330188, 0x0, 0x303304C8, 0x1, 0x303303F0
- #define IOMUXC\_SAI1\_TXC\_SAI5\_TX\_BCLK 0x30330188, 0x1, 0x303304E8, 0x1, 0x303303F0
- #define IOMUXC\_SAI1\_TXC\_CORESIGHT\_EVENTI 0x30330188, 0x4, 0x00000000, 0x0, 0x303303F0
- #define **IOMUXC SAI1 TXC GPIO4 IO11** 0x30330188, 0x5, 0x00000000, 0x0, 0x303303F0
- #define IOMUXC\_SAI1\_TXD0\_SAI1\_TX\_DATA0 0x3033018C, 0x0, 0x000000000, 0x0, 0x303303F4
- #define IOMUXC\_SAI1\_TXD0\_SAI5\_TX\_DATA0 0x3033018C, 0x1, 0x00000000, 0x0, 0x303303F4
- #define IOMUXC\_SAI1\_TXD0\_CORESIGHT\_TRACE8 0x3033018C, 0x4, 0x00000000, 0x0, 0x303303F4
- #define IOMUXC\_SAI1\_TXD0\_GPIO4\_IO12 0x3033018C, 0x5, 0x000000000, 0x0, 0x303303F4
- #define IOMUXC\_SAI1\_TXD0\_SRC\_BOOT\_CFG8 0x3033018C, 0x6, 0x000000000, 0x0, 0x303303F4
- #define IOMUXC\_SAI1\_TXD1\_SAI1\_TX\_DATA1 0x30330190, 0x0, 0x000000000, 0x0, 0x303303F8
- #define IOMUXC\_SAI1\_TXD1\_SAI5\_TX\_DATA1 0x30330190, 0x1, 0x00000000, 0x0, 0x303303F8
- #define IOMUXC\_SAI1\_TXD1\_CORESIGHT\_TRACE9 0x30330190, 0x4, 0x00000000, 0x0, 0x303303F8
- #define IOMUXC SAI1 TXD1 GPIO4 IO13 0x30330190, 0x5, 0x000000000, 0x0, 0x303303F8
- #define IOMUXC\_SAI1\_TXD1\_SRC\_BOOT\_CFG9 0x30330190, 0x6, 0x000000000, 0x0, 0x303303F8
- #define IOMUXC\_SAI1\_TXD2\_SAI1\_TX\_DATA2 0x30330194, 0x0, 0x00000000, 0x0, 0x303303FC
- #define IOMUXC\_SAI1\_TXD2\_SAI5\_TX\_DATA2 0x30330194, 0x1, 0x00000000, 0x0, 0x303303FC
- #define IOMUXC\_SAI1\_TXD2\_CORESIGHT\_TRACE10 0x30330194, 0x4, 0x000000000, 0x0, 0x303303FC
- #define IOMUXC SAI1 TXD2 GPIO4 IO14 0x30330194, 0x5, 0x00000000, 0x0, 0x303303FC
- #define IOMUXC\_SAIT\_TXD2\_SRC\_BOOT\_CFG10 0x30330194, 0x6, 0x000000000, 0x0, 0x303303FC
- #define IOMUXC\_SAI1\_TXD3\_SAI1\_TX\_DATA3 0x30330198, 0x0, 0x000000000, 0x0, 0x30330400
- #define IOMUXC\_SAI1\_TXD3\_SAI5\_TX\_DATA3 0x30330198, 0x1, 0x000000000, 0x0,

#### Overview

- 0x30330400
- #define IOMUXC SAI1 TXD3 CORESIGHT TRACE11 0x30330198, 0x4, 0x000000000, 0x0, 0x30330400
- #define IOMUXC\_SAI1\_TXD3\_GPIO4\_IO15 0x30330198, 0x5, 0x000000000, 0x0, 0x30330400
- #define IOMUXC SAI1 TXD3 SRC BOOT CFG11 0x30330198, 0x6, 0x000000000, 0x0, 0x30330400
- #define IOMUXC\_SAI1\_TXD4\_SAI1\_TX\_DATA4 0x3033019C, 0x0, 0x000000000, 0x0, 0x30330404
- #define IOMUXC SAI1 TXD4 SAI6 RX BCLK 0x3033019C. 0x1. 0x30330510. 0x1. 0x30330404
- #define IOMUXC SAI1 TXD4 SAI6 TX BCLK 0x3033019C, 0x2, 0x3033051C, 0x1,
- #define IOMUXC SAI1 TXD4 CORESIGHT TRACE12 0x3033019C, 0x4, 0x00000000, 0x0, 0x30330404
- #define IOMUXC\_SAI1\_TXD4\_GPIO4\_IO16 0x3033019C, 0x5, 0x000000000, 0x0, 0x30330404
- #define IOMUXC SAI1 TXD4 SRC BOOT CFG12 0x3033019C, 0x6, 0x000000000, 0x0,
- #define IOMUXC SAI1 TXD5 SAI1 TX DATA5 0x303301A0, 0x0, 0x000000000, 0x0, 0x30330408
- #define IOMUXC SAI1 TXD5 SAI6 RX DATA0 0x303301A0, 0x1, 0x30330514, 0x1, 0x30330408
- #define IOMUXC\_SAI1\_TXD5\_SAI6\_TX\_DATA0 0x303301A0, 0x2, 0x000000000, 0x0, 0x30330408
- #define IOMUXC SAI1 TXD5 CORESIGHT TRACE13 0x303301A0, 0x4, 0x000000000, 0x0, 0x30330408
- #define IOMUXC SAI1 TXD5 GPIO4 IO17 0x303301A0, 0x5, 0x000000000, 0x0, 0x30330408
- #define IOMUXC SAI1 TXD5 SRC BOOT CFG13 0x303301A0, 0x6, 0x000000000, 0x0, 0x30330408
- #define IOMUXC\_SAI1\_TXD6\_SAI1\_TX\_DATA6 0x303301A4, 0x0, 0x000000000, 0x0, 0x3033040C
- #define IOMUXC SAI1 TXD6 SAI6 RX SYNC 0x303301A4, 0x1, 0x30330518. 0x1.0x3033040C
- #define IOMUXC SAI1 TXD6 SAI6 TX SYNC 0x303301A4, 0x2, 0x30330520, 0x10x3033040C
- #define IOMUXC SAI1 TXD6 CORESIGHT TRACE14 0x303301A4, 0x4, 0x000000000, 0x0, 0x3033040C
- #define IOMUXC\_SAI1\_TXD6\_GPIO4\_IO18 0x303301A4, 0x5, 0x00000000, 0x0, 0x3033040-
- #define IOMUXC SAI1 TXD6 SRC BOOT CFG14 0x303301A4. 0x6. 0x00000000. 0x0. 0x3033040C
- #define IOMUXC SAI1 TXD7 SAI1 TX DATA7 0x303301A8, 0x0, 0x000000000, 0x0, 0x30330410
- #define IOMUXC\_SAI1\_TXD7\_SAI6\_MCLK 0x303301A8, 0x1, 0x30330530, 0x1, 0x30330410
- #define IOMUXC\_SAII\_TXD7\_CORESIGHT\_TRACE15 0x303301A8, 0x4, 0x00000000, 0x0. 0x30330410
- #define IOMUXC SAI1 TXD7 GPIO4 IO19 0x303301A8, 0x5, 0x000000000, 0x0, 0x30330410
- #define IOMUXC\_SAII\_TXD7\_SRC\_BOOT\_CFG15 0x303301A8, 0x6, 0x000000000, 0x0,
- #define IOMUXC\_SAI1\_MCLK\_SAI1\_MCLK 0x303301AC, 0x0, 0x000000000, 0x0, 0x30330414
   #define IOMUXC\_SAI1\_MCLK\_SAI5\_MCLK 0x303301AC, 0x1, 0x3033052C, 0x1, 0x30330414
- #define IOMUXC\_SAI1\_MCLK\_SAI1\_TX\_BCLK 0x303301AC, 0x2, 0x303304C8, 0x2,

- 0x30330414
- #define IOMUXC SAI1 MCLK GPIO4 IO20 0x303301AC, 0x5, 0x000000000, 0x0, 0x30330414
- #define IOMUXC SAI2 RXFS SAI2 RX SYNC 0x303301B0, 0x0, 0x000000000, 0x0. 0x30330418
- #define IOMUXC SAI2 RXFS SAI5 TX SYNC 0x303301B0, 0x1, 0x303304EC, 0x2, 0x30330418
- #define IOMUXC\_SAI2\_RXFS\_GPIO4\_IO21 0x303301B0, 0x5, 0x000000000, 0x0, 0x30330418
- #define IOMUXC SAI2 RXC SAI2 RX BCLK 0x303301B4, 0x0.0x000000000. 0x3033041C
- #define IOMUXC SAI2 RXC SAI5 TX BCLK 0x303301B4, 0x1, 0x303304E8. 0x2. 0x3033041C
- #define IOMUXC\_SAI2\_RXC\_GPIO4\_IO22 0x303301B4, 0x5, 0x00000000, 0x0, 0x3033041C
- #define IOMUXC SAI2 RXD0 SAI2 RX DATA0 0x303301B8, 0x0, 0x000000000, 0x0, 0x30330420
- #define IOMUXC\_SAI2\_RXD0\_SAI5\_TX\_DATA0 0x303301B8, 0x1, 0x000000000, 0x0, 0x30330420
- #define IOMUXC\_SAI2\_RXD0\_GPIO4\_IO23 0x303301B8, 0x5, 0x000000000, 0x0, 0x30330420
- #define IOMUXC\_SAI2\_TXFS\_SAI2\_TX\_SYNC 0x303301BC, 0x0, 0x000000000, 0x30330424
- #define IOMUXC SAI2 TXFS SAI5 TX DATA1 0x303301BC, 0x1, 0x00000000, 0x0. 0x30330424
- #define IOMUXC\_SAI2\_TXFS\_GPIO4\_IO24 0x303301BC, 0x5, 0x000000000, 0x0, 0x30330424
- #define IOMUXC SAI2 TXC SAI2 TX BCLK 0x303301C0, 0x0, 0x00000000. 0x30330428
- #define IOMUXC\_SAI2\_TXC\_SAI5\_TX\_DATA2 0x303301C0, 0x1, 0x000000000, 0x0, 0x30330428
- #define IOMUXC\_SAI2\_TXC\_GPIO4\_IO25 0x303301C0, 0x5, 0x000000000, 0x0, 0x30330428
- #define IOMUXC SAI2 TXD0 SAI2 TX DATA0 0x303301C4, 0x0, 0x000000000, 0x0, 0x3033042C
- #define IOMUXC SAI2 TXD0 SAI5 TX DATA3 0x303301C4, 0x1, 0x00000000, 0x0, 0x3033042C
- #define IOMUXC SAI2 TXD0 GPIO4 IO26 0x303301C4, 0x5, 0x00000000, 0x0, 0x3033042-
- #define IOMUXC\_SAI2\_MCLK\_SAI2\_MCLK 0x303301C8, 0x0, 0x000000000, 0x0, 0x30330430
   #define IOMUXC\_SAI2\_MCLK\_SAI5\_MCLK 0x303301C8, 0x1, 0x3033052C, 0x2, 0x30330430
- #define IOMUXC\_SAI2\_MCLK\_GPIO4\_IO27 0x303301C8, 0x5, 0x000000000, 0x0, 0x30330430
- #define IOMUXC SAI3 RXFS SAI3 RX SYNC 0x303301CC, 0x0, 0x00000000, 0x30330434
- #define IOMUXC SAI3 RXFS GPT1 CAPTURE1 0x303301CC, 0x1, 0x000000000, 0x0, 0x30330434
- #define IOMUXC\_SAI3\_RXFS\_SAI5\_RX\_SYNC 0x303301CC, 0x2, 0x303304E4, 0x2.
- #define IOMUXC\_SAI3\_RXFS\_GPIO4\_IO28 0x303301CC, 0x5, 0x000000000, 0x0, 0x30330434
- #define IOMUXC\_SAI3\_RXC\_SAI3\_RX\_BCLK 0x303301D0, 0x0, 0x000000000. 0x0, 0x30330438
- #define IOMUXC SAI3 RXC GPT1 CAPTURE2 0x303301D0, 0x1, 0x00000000, 0x0, 0x30330438
- #define IOMUXC\_SAI3\_RXC\_SAI5\_RX\_BCLK 0x303301D0, 0x2, 0x303304D0, 0x20x30330438
- #define IOMUXC SAI3 RXC GPIO4 IO29 0x303301D0, 0x5, 0x00000000, 0x0, 0x30330438
- #define IOMUXC\_SAI3\_RXD\_SAI3\_RX\_DATA0 0x303301D4, 0x0, 0x00000000,

MCUXpresso SDK API Reference Manual

#### Overview

- 0x3033043C
- #define IOMUXC SAI3 RXD GPT1 COMPARE1 0x303301D4. 0x1. 0x000000000. 0x0. 0x3033043C
- #define IOMUXC SAI3\_RXD\_SAI5\_RX\_DATA0 0x303301D4, 0x2, 0x303304D4, 0x2, 0x3033043C
- #define IOMUXC SAI3 RXD GPIO4 IO30 0x303301D4, 0x5, 0x00000000, 0x0, 0x3033043C
- #define IOMUXC\_SAI3\_TXFS\_SAI3\_TX\_SYNC 0x303301D8, 0x0, 0x000000000, 0x0, 0x30330440
- #define IOMUXC SAI3 TXFS GPT1 CLK 0x303301D8, 0x1, 0x00000000, 0x0, 0x30330440
- #define IOMUXC\_SAI3\_TXFS\_SAI5\_RX\_DATA1 0x303301D8, 0x2, 0x303304D8, 0x2, 0x30330440
- #define IOMUXC SAI3 TXFS GPIO4 IO31 0x303301D8, 0x5, 0x000000000, 0x0, 0x30330440
- #define IOMUXC SAI3 TXC SAI3 TX BCLK 0x303301DC, 0x0, 0x00000000,
- #define IOMUXC\_SAI3\_TXC\_GPT1\_COMPARE2 0x303301DC, 0x1, 0x00000000, 0x0, 0x30330444
- #define IOMUXC\_SAI3\_TXC\_SAI5\_RX\_DATA2 0x303301DC, 0x2, 0x303304DC, 0x2, 0x30330444
- #define IOMUXC\_SAI3\_TXC\_GPIO5\_IO00 0x303301DC, 0x5, 0x00000000, 0x0, 0x30330444
- #define IOMUXC SAI3 TXD SAI3 TX DATA0 0x303301E0, 0x0, 0x00000000. 0x30330448
- #define IOMUXC SAI3 TXD GPT1 COMPARE3 0x303301E0, 0x1, 0x000000000, 0x0, 0x30330448
- #define IOMUXC SAI3 TXD SAI5 RX DATA3 0x303301E0, 0x2, 0x303304E0, 0x2, 0x30330448
- #define IOMUXC\_SAI3\_TXD\_GPIO5\_IO01 0x303301E0, 0x5, 0x000000000, 0x0, 0x30330448
- #define IOMUXC SAI3 MCLK SAI3 MCLK 0x303301E4, 0x0, 0x000000000, 0x0, 0x3033044-
- #define IOMUXC SAI3 MCLK PWM4 OUT 0x303301E4, 0x1, 0x000000000, 0x0, 0x3033044-
- #define IOMUXC SAI3 MCLK SAI5 MCLK 0x303301E4, 0x2, 0x3033052C, 0x3, 0x3033044-
- #define IOMUXC\_SAI3\_MCLK\_GPIO5\_IO02 0x303301E4, 0x5, 0x00000000, 0x0, 0x3033044-
- #define IOMUXC SPDIF TX SPDIF1 OUT 0x303301E8, 0x0, 0x00000000, 0x0, 0x30330450
- #define **IOMUXC\_SPDIF\_TX\_PWM3\_OUT** 0x303301E8, 0x1, 0x00000000, 0x0, 0x30330450 #define **IOMUXC\_SPDIF\_TX\_GPIO5\_IO03** 0x303301E8, 0x5, 0x00000000, 0x0, 0x30330450
- #define **IOMUXC\_SPDIF\_RX\_SPDIF1\_IN** 0x303301EC, 0x0, 0x00000000, 0x0, 0x30330454
- #define IOMUXC\_SPDIF\_RX\_PWM2\_OUT 0x303301EC, 0x1, 0x00000000, 0x0, 0x30330454
- #define IOMUXC SPDIF RX GPIO5 IO04 0x303301EC, 0x5, 0x00000000, 0x0, 0x30330454
- #define IOMUXC\_SPDIF\_EXT\_CLK\_SPDIF1\_EXT\_CLK\_0x303301F0, 0x0, 0x00000000,
- 0x0, 0x30330458
- #define IOMUXC SPDIF EXT CLK PWM1 OUT 0x303301F0, 0x1, 0x000000000, 0x0, 0x30330458
- #define IOMUXC SPDIF EXT CLK GPIO5 IO05 0x303301F0, 0x5, 0x000000000, 0x0, 0x30330458
- #define IOMUXC ECSPI1 SCLK ECSPI1 SCLK 0x303301F4, 0x0, 0x000000000, 0x0, 0x3033045C
- #define IOMUXC ECSPI1 SCLK UART3 RX 0x303301F4, 0x1, 0x30330504, 0x0, 0x3033045-
- #define IOMUXC\_ECSPI1\_SCLK\_UART3\_TX 0x303301F4, 0x1, 0x000000000. 0X0

- 0x3033045C
- #define IOMUXC\_ECSPI1\_SCLK\_GPIO5\_IO06 0x303301F4, 0x5, 0x000000000, 0x0, 0x3033045C
- #define IOMUXC\_ECSPI1\_MOSI\_ECSPI1\_MOSI 0x303301F8, 0x0, 0x00000000, 0x0, 0x30330460
- #define IOMUXC\_ECSPI1\_MOSI\_UART3\_TX 0x303301F8, 0x1, 0x00000000, 0X0, 0x30330460
- #define IOMUXC\_ECSPI1\_MOSI\_UART3\_RX 0x303301F8, 0x1, 0x30330504, 0x1, 0x30330460
- #define IOMUXC\_ECSPI1\_MOSI\_GPIO5\_IO07 0x303301F8, 0x5, 0x00000000, 0x0, 0x30330460
- #define IOMUXC\_ECSPI1\_MISO\_ECSPI1\_MISO 0x303301FC, 0x0, 0x000000000, 0x0, 0x30330464
- #define IOMUXC\_ECSPI1\_MISO\_UART3\_CTS\_B 0x303301FC, 0x1, 0x00000000, 0X0, 0x30330464
- #define IOMUXC\_ECSPI1\_MISO\_UART3\_RTS\_B 0x303301FC, 0x1, 0x30330500, 0x0, 0x30330464
- #define IOMUXC\_ECSPI1\_MISO\_GPIO5\_IO08 0x303301FC, 0x5, 0x00000000, 0x0, 0x30330464
- #define IOMUXC\_ECSPI1\_SS0\_ECSPI1\_SS0 0x30330200, 0x0, 0x000000000, 0x0, 0x30330468
- #define IOMUXC\_ECSPI1\_SS0\_UART3\_RTS\_B 0x30330200, 0x1, 0x30330500, 0x1, 0x30330468
- #define IOMUXC\_ECSPI1\_SS0\_UART3\_CTS\_B 0x30330200, 0x1, 0x000000000, 0X0, 0x30330468
- #define IOMUXC\_ECSPI1\_SS0\_GPIO5\_IO09 0x30330200, 0x5, 0x000000000, 0x0, 0x30330468
- #define IOMUXC\_ECSPI2\_SCLK\_ECSPI2\_SCLK 0x30330204, 0x0, 0x000000000, 0x0, 0x3033046C
- #define IOMUXC\_ECSPI2\_SCLK\_UART4\_RX 0x30330204, 0x1, 0x3033050C, 0x0, 0x3033046-C
- #define IOMUXC\_ECSPI2\_SCLK\_UART4\_TX 0x30330204, 0x1, 0x00000000, 0X0, 0x3033046C
- #define IOMUXC\_ECSPI2\_SCLK\_GPIO5\_IO10 0x30330204, 0x5, 0x000000000, 0x0, 0x3033046C
- #define IOMUXC\_ECSPI2\_MOSI\_ECSPI2\_MOSI 0x30330208, 0x0, 0x000000000, 0x0, 0x30330470
- #define IOMUXC ECSPI2 MOSI UART4 TX 0x30330208, 0x1, 0x000000000, 0X0, 0x30330470
- #define IOMUXC ECSPI2 MOSI UART4 RX 0x30330208, 0x1, 0x3033050C, 0x1, 0x30330470
- #define IOMUXC\_ECSPI2\_MOSI\_GPIO5\_IO11 0x30330208, 0x5, 0x000000000, 0x0, 0x30330470
- #define IOMUXC\_ECSPI2\_MISO\_ECSPI2\_MISO 0x3033020C, 0x0, 0x000000000, 0x0, 0x30330474
- #define IOMUXC\_ECSPI2\_MISO\_UART4\_CTS\_B 0x3033020C, 0x1, 0x00000000, 0X0, 0x30330474
- #define IOMUXC\_ECSPI2\_MISO\_UART4\_RTS\_B 0x3033020C, 0x1, 0x30330508, 0x0, 0x30330474
- #define IOMUXC\_ECSPI2\_MISO\_GPIO5\_IO12 0x3033020C, 0x5, 0x000000000, 0x0, 0x30330474
- #define IOMUXC\_ECSPI2\_SS0\_ECSPI2\_SS0 0x30330210, 0x0, 0x000000000, 0x0, 0x30330478
- #define IOMUXC\_ECSPI2\_SSO\_UART4\_RTS\_B 0x30330210, 0x1, 0x30330508, 0x1, 0x30330478
- #define IOMUXC\_ECSPI2\_SS0\_UART4\_CTS\_B 0x30330210, 0x1, 0x000000000, 0X0,

#### Overview

#### 0x30330478

- #define **IOMUXC ECSPI2 SS0 GPIO5 IO13** 0x30330210, 0x5, 0x00000000, 0x0, 0x30330478
- #define IOMUXC\_I2C1\_SCL\_I2C1\_SCL 0x30330214, 0x0, 0x00000000, 0x0, 0x3033047C
- #define IOMUXC I2C1 SCL ENET1 MDC 0x30330214, 0x1, 0x00000000, 0x0, 0x3033047C
- #define IOMUXC I2C1 SCL GPIO5 IO14 0x30330214, 0x5, 0x00000000, 0x0, 0x3033047C
- #define IOMUXC I2C1 SDA I2C1 SDA 0x30330218, 0x0, 0x00000000, 0x0, 0x30330480
- #define IOMUXC\_I2C1\_SDA\_ENET1\_MDIO 0x30330218, 0x1, 0x303304C0, 0x2, 0x30330480
   #define IOMUXC\_I2C1\_SDA\_GPIO5\_IO15 0x30330218, 0x5, 0x00000000, 0x0, 0x30330480
- #define IOMUXC\_I2C2\_SCL\_I2C2\_SCL 0x3033021C, 0x0, 0x00000000, 0x0, 0x30330484
- #define IOMUXC 12C2 SCL ENET1 1588 EVENT1 IN 0x3033021C, 0x1, 0x00000000, 0x0,
- #define IOMUXC I2C2 SCL GPIO5 IO16 0x3033021C, 0x5, 0x00000000, 0x0, 0x30330484
- #define IOMUXC I2C2 SDA I2C2 SDA 0x30330220, 0x0, 0x000000000, 0x0, 0x30330488
- #define IOMUXC\_I2C2\_SDA\_ENET1\_1588\_EVENT1\_OUT 0x30330220, 0x1, 0x00000000, 0x0, 0x30330488
- #define IOMUXC I2C2 SDA GPIO5 IO17 0x30330220, 0x5, 0x00000000, 0x0, 0x30330488
- #define IOMUXC 12C3 SCL 12C3 SCL 0x30330224, 0x0, 0x000000000, 0x0, 0x3033048C
- #define **IOMUXC\_I2C3\_SCL\_PWM4\_OUT** 0x30330224, 0x1, 0x00000000, 0x0, 0x3033048C
- #define **IOMUXC\_I2C3\_SCL\_GPT2\_CLK** 0x30330224, 0x2, 0x00000000, 0x0, 0x3033048C
- #define IOMUXC\_I2C3\_SCL\_GPIO5\_IO18 0x30330224, 0x5, 0x00000000, 0x0, 0x3033048C
- #define IOMUXC\_I2C3\_SDA\_I2C3\_SDA 0x30330228, 0x0, 0x00000000, 0x0, 0x30330490
- #define IOMUXC\_I2C3\_SDA\_PWM3\_OUT 0x30330228, 0x1, 0x00000000, 0x0, 0x30330490
- #define **IOMUXC 12C3 SDA GPT3 CLK** 0x30330228, 0x2, 0x00000000, 0x0, 0x30330490
- #define **IOMUXC\_I2C3\_SDA\_GPIO5\_IO19** 0x30330228, 0x5, 0x00000000, 0x0, 0x30330490
- #define IOMUXC\_I2C4\_SCL\_I2C4\_SCL 0x3033022C, 0x0, 0x00000000, 0x0, 0x30330494
- #define IOMUXC I2C4 SCL PWM2 OUT 0x3033022C, 0x1, 0x00000000, 0x0, 0x30330494
- #define IOMUXC I2C4 SCL PCIE1 CLKREO B 0x3033022C, 0x2, 0x30330524, 0x0, 0x30330494
- #define IOMUXC I2C4 SCL GPIO5 IO20 0x3033022C, 0x5, 0x000000000, 0x0, 0x30330494
- #define IOMUXC I2C4 SDA I2C4 SDA 0x30330230, 0x0, 0x00000000, 0x0, 0x30330498
- #define IOMUXC I2C4 SDA PWM1 OUT 0x30330230, 0x1, 0x00000000, 0x0, 0x30330498
- #define IOMUXC I2C4 SDA PCIE2 CLKREO B 0x30330230, 0x2, 0x30330528, 0x0, 0x30330498
- #define IOMUXC I2C4 SDA GPIO5 IO21 0x30330230, 0x5, 0x000000000, 0x0, 0x30330498
- #define IOMUXC UART1 RXD UART1 RX 0x30330234, 0x0, 0x303304F4, 0x0, 0x3033049-
- #define IOMUXC UART1 RXD UART1 TX 0x30330234, 0x0, 0x000000000, 0X0, 0x3033049-
- #define IOMUXC UART1 RXD ECSPI3 SCLK 0x30330234, 0x1, 0x00000000, 0x0, 0x3033049C
- #define IOMUXC UART1 RXD GPIO5 IO22 0x30330234, 0x5, 0x000000000, 0x0, 0x3033049-
- #define IOMUXC\_UART1\_TXD\_UART1\_TX 0x30330238, 0x0, 0x00000000, 0X0, 0x303304-
- #define IOMUXC UART1 TXD UART1 RX 0x30330238, 0x0, 0x303304F4, 0x1, 0x303304-
- #define IOMUXC UART1 TXD ECSPI3 MOSI 0x30330238, 0x1, 0x00000000, 0x303304A0
- #define IOMUXC UART1 TXD GPIO5 IO23 0x30330238, 0x5, 0x000000000, 0x0, 0x303304-
- #define IOMUXC\_UART2\_RXD\_UART2\_RX 0x3033023C, 0x0, 0x303304FC, 0x0, 0x303304-
- #define IOMUXC UART2 RXD UART2 TX 0x3033023C, 0x0, 0x000000000, 0X0, 0x303304-

A4

- #define IOMUXC\_UART2\_RXD\_ECSPI3\_MISO 0x3033023C, 0x1, 0x00000000, 0x0, 0x303304A4
- #define IOMUXC\_UART2\_RXD\_GPIO5\_IO24 0x3033023C, 0x5, 0x000000000, 0x0, 0x303304-A4
- #define IOMUXC\_UART2\_TXD\_UART2\_TX 0x30330240, 0x0, 0x000000000, 0X0, 0x303304-A8
- #define IOMUXC\_UART2\_TXD\_UART2\_RX 0x30330240, 0x0, 0x303304FC, 0x1, 0x303304-A8
- #define IOMUXC\_UART2\_TXD\_ECSPI3\_SS0 0x30330240, 0x1, 0x000000000, 0x0, 0x303304-A8
- #define IOMUXC\_UART2\_TXD\_GPIO5\_IO25 0x30330240, 0x5, 0x000000000, 0x0, 0x303304-A8
- #define IOMUXC\_UART3\_RXD\_UART3\_RX 0x30330244, 0x0, 0x30330504, 0x2, 0x303304-AC
- #define IOMUXC\_UART3\_RXD\_UART3\_TX 0x30330244, 0x0, 0x000000000, 0X0, 0x303304-AC
- #define IOMUXC\_UART3\_RXD\_UART1\_CTS\_B 0x30330244, 0x1, 0x00000000, 0X0, 0x303304AC
- #define **IOMUXC\_UART3\_RXD\_UART1\_RTS\_B** 0x30330244, 0x1, 0x303304F0, 0x0, 0x303304AC
- #define IOMUXC\_UART3\_RXD\_GPIO5\_IO26 0x30330244, 0x5, 0x00000000, 0x0, 0x303304-AC
- #define IOMUXC\_UART3\_TXD\_UART3\_TX 0x30330248, 0x0, 0x00000000, 0X0, 0x303304-B0
- #define IOMUXC\_UART3\_TXD\_UART3\_RX 0x30330248, 0x0, 0x30330504, 0x3, 0x303304-B0
- #define IOMUXC\_UART3\_TXD\_UART1\_RTS\_B 0x30330248, 0x1, 0x303304F0, 0x1, 0x303304B0
- #define IOMUXC\_UART3\_TXD\_UART1\_CTS\_B 0x30330248, 0x1, 0x00000000, 0X0, 0x303304B0
- #define IOMUXC\_UART3\_TXD\_GPIO5\_IO27 0x30330248, 0x5, 0x000000000, 0x0, 0x303304-B0
- #define IOMUXC\_UART4\_RXD\_UART4\_RX 0x3033024C, 0x0, 0x3033050C, 0x2, 0x303304-B4
- #define IOMUXC\_UART4\_RXD\_UART4\_TX 0x3033024C, 0x0, 0x000000000, 0X0, 0x303304-B4
- #define IOMUXC\_UART4\_RXD\_UART2\_CTS\_B 0x3033024C, 0x1, 0x00000000, 0X0, 0x303304B4
- #define IOMUXC\_UART4\_RXD\_UART2\_RTS\_B 0x3033024C, 0x1, 0x303304F8, 0x0, 0x303304B4
- #define IOMUXC\_UART4\_RXD\_PCIE1\_CLKREQ\_B 0x3033024C, 0x2, 0x30330524, 0x1, 0x303304B4
- #define IOMUXC\_UART4\_RXD\_GPIO5\_IO28 0x3033024C, 0x5, 0x000000000, 0x0, 0x303304-B4
- #define IOMUXC\_UART4\_TXD\_UART4\_TX 0x30330250, 0x0, 0x000000000, 0X0, 0x303304-B8
- #define IOMUXC\_UART4\_TXD\_UART4\_RX 0x30330250, 0x0, 0x3033050C, 0x3, 0x303304-B8
- #define IOMUXC\_UART4\_TXD\_UART2\_RTS\_B 0x30330250, 0x1, 0x303304F8, 0x1,

#### **Function Documentation**

- 0x303304B8
- #define IOMUXC UART4 TXD UART2 CTS B 0x30330250, 0x1, 0x000000000, 0X0, 0x303304B8
- #define IOMUXC\_UART4\_TXD\_PCIE2\_CLKREQ\_B 0x30330250, 0x2, 0x30330528, 0x1, 0x303304B8
- #define IOMUXC UART4 TXD GPIO5 IO29 0x30330250, 0x5, 0x000000000, 0x0, 0x303304-

- #define **IOMUXC\_JTAG\_MOD** 0x00000000, 0x0, 0x00000000, 0x0, 0x30330260
- #define **IOMUXC JTAG TRST B** 0x00000000, 0x0, 0x00000000, 0x0, 0x30330264
- #define **IOMUXC\_JTAG\_TDI** 0x00000000, 0x0, 0x00000000, 0x0, 0x30330268
- #define IOMUXC\_JTAG\_TMS 0x00000000, 0x0, 0x00000000, 0x0, 0x3033026C
  #define IOMUXC\_JTAG\_TCK 0x00000000, 0x0, 0x00000000, 0x0, 0x30330270
  #define IOMUXC\_JTAG\_TDO 0x00000000, 0x0, 0x00000000, 0x0, 0x30330274

- #define **IOMUXC RTC** 0x00000000, 0x0, 0x00000000, 0x0, 0x30330278

#### Configuration

- static void IOMUXC\_SetPinMux (uint32\_t muxRegister, uint32\_t muxMode, uint32\_t input-Register, uint32 t inputDaisy, uint32 t configRegister, uint32 t inputOnfield) Sets the IOMUXC pin mux mode.
- static void IOMUXC\_SetPinConfig (uint32\_t muxRegister, uint32\_t muxMode, uint32\_t input-Register, uint32\_t inputDaisy, uint32\_t configRegister, uint32\_t configValue) Sets the IOMUXC pin configuration.
- 20.2 **Macro Definition Documentation**
- 20.2.1 #define FSL IOMUXC DRIVER VERSION (MAKE VERSION(2, 0, 0))
- 20.3 **Function Documentation**
- static void IOMUXC SetPinMux ( uint32 t muxRegister, uint32 t muxMode, uint32 t inputRegister, uint32 t inputDaisy, uint32 t configRegister, uint32 t inputOnfield ) [inline],[static]

Note

The first five parameters can be filled with the pin function ID macros.

This is an example to set the I2C4\_SDA as the pwm1\_OUT:

\* IOMUXC\_SetPinMux(IOMUXC\_I2C4\_SDA\_PWM1\_OUT, 0);

#### **Parameters**

| muxRegister    | The pin mux register_            |
|----------------|----------------------------------|
| muxMode        | The pin mux mode_                |
| inputRegister  | The select input register_       |
| inputDaisy     | The input daisy_                 |
| configRegister | The config register_             |
| inputInv       | The pad->module input inversion_ |

# 20.3.2 static void IOMUXC\_SetPinConfig ( uint32\_t muxRegister, uint32\_t muxMode, uint32\_t inputRegister, uint32\_t inputDaisy, uint32\_t configRegister, uint32\_t configValue ) [inline], [static]

Note

The previous five parameters can be filled with the pin function ID macros.

This is an example to set pin configuration for IOMUXC\_I2C4\_SDA\_PWM1\_OUT:

```
* IOMUXC_SetPinConfig(IOMUXC_I2C4_SDA_PWM1_OUT, IOMUXC_SW_PAD_CTL_PAD_ODE_MASK | IOMUXC0_SW_PAD_CTL_PAD_DSE(2U))
```

#### **Parameters**

| muxRegister    | The pin mux register_      |
|----------------|----------------------------|
| muxMode        | The pin mux mode_          |
| inputRegister  | The select input register_ |
| inputDaisy     | The input daisy_           |
| configRegister | The config register_       |
| configValue    | The pin config value_      |

**Function Documentation** 

## **Chapter 21 Debug Console**

#### 21.1 Overview

This chapter describes the programming interface of the debug console driver.

The debug console enables debug log messages to be output via the specified peripheral with frequency of the peripheral source clock and base address at the specified baud rate. Additionally, it provides input and output functions to scan and print formatted data.

## 21.2 Function groups

#### 21.2.1 Initialization

To initialize the debug console, call the DbgConsole\_Init() function with these parameters. This function automatically enables the module and the clock.

Selects the supported debug console hardware device type, such as

```
typedef enum _serial_port_type
{
    kSerialPort_Uart = 1U,
    kSerialPort_UsbCdc,
    kSerialPort_Swo,
} serial_port_type_t;
```

After the initialization is successful, stdout and stdin are connected to the selected peripheral.

This example shows how to call the DbgConsole\_Init() given the user configuration structure.

```
DbgConsole_Init(BOARD_DEBUG_UART_INSTANCE, BOARD_DEBUG_UART_BAUDRATE, BOARD_DEBUG_UART_TYPE, BOARD_DEBUG_UART_CLK_FREQ);
```

#### 21.2.2 Advanced Feature

The debug console provides input and output functions to scan and print formatted data.

• Support a format specifier for PRINTF following this prototype " %[flags][width][.precision][length]specifier", which is explained below

MCUXpresso SDK API Reference Manual

## **Function groups**

| flags   | Description                                                                                                                                                                                                                                                                                                                                                                             |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -       | Left-justified within the given field width. Right-justified is the default.                                                                                                                                                                                                                                                                                                            |
| +       | Forces to precede the result with a plus or minus sign (+ or -) even for positive numbers. By default, only negative numbers are preceded with a - sign.                                                                                                                                                                                                                                |
| (space) | If no sign is written, a blank space is inserted before the value.                                                                                                                                                                                                                                                                                                                      |
| #       | Used with o, x, or X specifiers the value is preceded with 0, 0x, or 0X respectively for values other than zero. Used with e, E and f, it forces the written output to contain a decimal point even if no digits would follow. By default, if no digits follow, no decimal point is written. Used with g or G the result is the same as with e or E but trailing zeros are not removed. |
| 0       | Left-pads the number with zeroes (0) instead of spaces, where padding is specified (see width subspecifier).                                                                                                                                                                                                                                                                            |

| Width    | Description                                                                                                                                                                                                     |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (number) | A minimum number of characters to be printed. If<br>the value to be printed is shorter than this number,<br>the result is padded with blank spaces. The value<br>is not truncated even if the result is larger. |
| *        | The width is not specified in the format string, but as an additional integer value argument preceding the argument that has to be formatted.                                                                   |

MCUXpresso SDK API Reference Manual

| .precision | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| .number    | For integer specifiers (d, i, o, u, x, X) precision specifies the minimum number of digits to be written. If the value to be written is shorter than this number, the result is padded with leading zeros. The value is not truncated even if the result is longer. A precision of 0 means that no character is written for the value 0. For e, E, and f specifiers this is the number of digits to be printed after the decimal point. For g and G specifiers This is the maximum number of significant digits to be printed. For s this is the maximum number of characters to be printed. By default, all characters are printed until the ending null character is encountered. For c type it has no effect. When no precision is specified, the default is 1. If the period is specified without an explicit value for precision, 0 is assumed. |
| .*         | The precision is not specified in the format string, but as an additional integer value argument preceding the argument that has to be formatted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| length         | Description |  |
|----------------|-------------|--|
| Do not support |             |  |

| specifier | Description                                  |
|-----------|----------------------------------------------|
| d or i    | Signed decimal integer                       |
| f         | Decimal floating point                       |
| F         | Decimal floating point capital letters       |
| X         | Unsigned hexadecimal integer                 |
| X         | Unsigned hexadecimal integer capital letters |
| 0         | Signed octal                                 |
| b         | Binary value                                 |
| p         | Pointer address                              |
| u         | Unsigned decimal integer                     |
| С         | Character                                    |
| s         | String of characters                         |
| n         | Nothing printed                              |

MCUXpresso SDK API Reference Manual

## **Function groups**

• Support a format specifier for SCANF following this prototype " %[\*][width][length]specifier", which is explained below

\* Description

An optional starting asterisk indicates that the data is to be read from the stream but ignored. In other words, it is not stored in the corresponding argument.

| width                                                                                        | Description |
|----------------------------------------------------------------------------------------------|-------------|
| This specifies the maximum number of characters to be read in the current reading operation. |             |

| length      | Description                                                                                                                                                                                             |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| hh          | The argument is interpreted as a signed character or unsigned character (only applies to integer specifiers: i, d, o, u, x, and X).                                                                     |
| h           | The argument is interpreted as a short integer or unsigned short integer (only applies to integer specifiers: i, d, o, u, x, and X).                                                                    |
| 1           | The argument is interpreted as a long integer or unsigned long integer for integer specifiers (i, d, o, u, x, and X) and as a wide character or wide character string for specifiers c and s.           |
| 11          | The argument is interpreted as a long long integer or unsigned long long integer for integer specifiers (i, d, o, u, x, and X) and as a wide character or wide character string for specifiers c and s. |
| L           | The argument is interpreted as a long double (only applies to floating point specifiers: e, E, f, g, and G).                                                                                            |
| j or z or t | Not supported                                                                                                                                                                                           |

| specifier | Qualifying Input                                                                                                                                                                                                                                 | Type of argument |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| С         | Single character: Reads the next character. If a width different from 1 is specified, the function reads width characters and stores them in the successive locations of the array passed as argument. No null character is appended at the end. | char *           |

#### **MCUXpresso SDK API Reference Manual**

| specifier              | Qualifying Input                                                                                                                                                                                                            | Type of argument |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| i                      | Integer: : Number optionally preceded with a + or - sign                                                                                                                                                                    | int *            |
| d                      | Decimal integer: Number optionally preceded with a + or - sign                                                                                                                                                              | int *            |
| a, A, e, E, f, F, g, G | Floating point: Decimal number containing a decimal point, optionally preceded by a + or - sign and optionally followed by the e or E character and a decimal number. Two examples of valid entries are -732.103 and 7.12e4 | float *          |
| 0                      | Octal Integer:                                                                                                                                                                                                              | int *            |
| s                      | String of characters. This reads subsequent characters until a white space is found (white space characters are considered to be blank, newline, and tab).                                                                  | char *           |
| u                      | Unsigned decimal integer.                                                                                                                                                                                                   | unsigned int *   |

The debug console has its own printf/scanf/putchar/getchar functions which are defined in the header file.

```
int DbgConsole_Printf(const char *fmt_s, ...);
int DbgConsole_Putchar(int ch);
int DbgConsole_Scanf(const char *fmt_ptr, ...);
int DbgConsole_Getchar(void);
```

This utility supports selecting toolchain's printf/scanf or the MCUXpresso SDK printf/scanf.

```
#if SDK_DEBUGCONSOLE
                       /* Select printf, scanf, putchar, getchar of SDK version. */
#define PRINTF
                             DbgConsole_Printf
                              DbgConsole_Scanf
#define SCANF
#define PUTCHAR
                              DbgConsole_Putchar
#define GETCHAR
                              DbgConsole_Getchar
#else
                       /* Select printf, scanf, putchar, getchar of toolchain. */
#define PRINTF
                            printf
#define SCANF
                              scanf
#define PUTCHAR
                              putchar
#define GETCHAR
                              getchar
#endif /* SDK_DEBUGCONSOLE */
```

## 21.3 Typical use case

## Some examples use the PUTCHAR & GETCHAR function

```
ch = GETCHAR();
PUTCHAR(ch);
```

MCUXpresso SDK API Reference Manual

#### Typical use case

### Some examples use the PRINTF function

Statement prints the string format.

```
PRINTF("%s %s\r\n", "Hello", "world!");
```

Statement prints the hexadecimal format/

```
PRINTF("0x%02X hexadecimal number equivalents 255", 255);
```

Statement prints the decimal floating point and unsigned decimal.

```
PRINTF("Execution timer: %s\n\rTime: %u ticks %2.5f milliseconds\n\rDONE\n\r", "1 day", 86400, 86.4);
```

## Some examples use the SCANF function

```
PRINTF("Enter a decimal number: ");
SCANF("%d", &i);
PRINTF("\r\nYou have entered %d.\r\n", i, i);
PRINTF("Enter a hexadecimal number: ");
SCANF("%x", &i);
PRINTF("\r\nYou have entered 0x%X (%d).\r\n", i, i);
```

## Print out failure messages using MCUXpresso SDK \_\_assert\_func:

```
void __assert_func(const char *file, int line, const char *func, const char *failedExpr)
{
    PRINTF("ASSERT ERROR \" %s \": file \"%s\" Line \"%d\" function name \"%s\" \n", failedExpr, file
    , line, func);
    for (;;)
    {}
}
```

#### Note:

To use 'printf' and 'scanf' for GNUC Base, add file 'fsl\_sbrk.c' in path: ..\{package}\devices\{subset}\utilities\fsl\_sbrk.c to your project.

#### **Modules**

- SWO
  - /\*!
- Semihosting

#### **Macros**

#define DEBUGCONSOLE\_REDIRECT\_TO\_TOOLCHAIN 0U

Definition select redirect toolchain printf, scanf to uart or not.

#define DEBUGCONSOLE\_REDIRECT\_TO\_SDK 1U

Select SDK version printf, scanf.

#define DEBUGCONSOLE\_DISABLE 2U

Disable debugconsole function.

#define SDK\_DEBUGCONSOLE 1U

Definition to select sdk or toolchain printf, scanf.

#define SDK DEBUGCONSOLE UART

Definition to select redirect toolchain printf, scanf to uart or not.

• #define PRINTF DbgConsole\_Printf

Definition to select redirect toolchain printf, scanf to uart or not.

## **Typedefs**

• typedef void(\* printfCb )(char \*buf, int32\_t \*indicator, char val, int len)

A function pointer which is used when format printf log.

#### **Functions**

• int StrFormatPrintf (const char \*fmt, va\_list ap, char \*buf, printfCb cb)

This function outputs its parameters according to a formatted string.

• int StrFormatScanf (const char \*line\_ptr, char \*format, va\_list args\_ptr)

Converts an input line of ASCII characters based upon a provided string format.

#### Initialization

• status\_t DbgConsole\_Init (uint8\_t instance, uint32\_t baudRate, serial\_port\_type\_t device, uint32\_t clkSrcFreq)

*Initializes the peripheral used for debug messages.* 

• status\_t DbgConsole\_Deinit (void)

De-initializes the peripheral used for debug messages.

• int DbgConsole\_Printf (const char \*formatString,...)

Writes formatted output to the standard output stream.

• int DbgConsole Putchar (int ch)

Writes a character to stdout.

• int DbgConsole\_Scanf (char \*formatString,...)

Reads formatted data from the standard input stream.

• int DbgConsole\_Getchar (void)

Reads a character from standard input.

• status t DbgConsole Flush (void)

Debug console flush.

#### 21.4 Macro Definition Documentation

## 21.4.1 #define DEBUGCONSOLE\_REDIRECT\_TO\_TOOLCHAIN 0U

Select toolchain printf and scanf.

MCUXpresso SDK API Reference Manual

#### **Function Documentation**

- 21.4.2 #define DEBUGCONSOLE\_REDIRECT\_TO\_SDK 1U
- 21.4.3 #define DEBUGCONSOLE\_DISABLE 2U
- 21.4.4 #define SDK\_DEBUGCONSOLE 1U
- 21.4.5 #define SDK DEBUGCONSOLE UART
- 21.4.6 #define PRINTF DbgConsole\_Printf

if SDK\_DEBUGCONSOLE defined to 0,it represents select toolchain printf, scanf. if SDK\_DEBUGCONSOLE defined to 1,it represents select SDK version printf, scanf. if SDK\_DEBUGCONSOLE defined to 2,it represents disable debugconsole function.

#### 21.5 Function Documentation

## 21.5.1 status\_t DbgConsole\_Init ( uint8\_t instance, uint32\_t baudRate, serial\_port\_type\_t device, uint32\_t clkSrcFreq )

Call this function to enable debug log messages to be output via the specified peripheral initialized by the serial manager module. After this function has returned, stdout and stdin are connected to the selected peripheral.

#### **Parameters**

| instance   | The instance of the module.                                                                                           |
|------------|-----------------------------------------------------------------------------------------------------------------------|
| baudRate   | The desired baud rate in bits per second.                                                                             |
| device     | Low level device type for the debug console, can be one of the following.  • kSerialPort_Uart,  • kSerialPort_UsbCdc. |
| clkSrcFreq | Frequency of peripheral source clock.                                                                                 |

#### Returns

Indicates whether initialization was successful or not.

331

#### Return values

| kStatus_Success | Execution successfully |
|-----------------|------------------------|
|-----------------|------------------------|

## 21.5.2 status\_t DbgConsole\_Deinit ( void )

Call this function to disable debug log messages to be output via the specified peripheral initialized by the serial manager module.

#### Returns

Indicates whether de-initialization was successful or not.

## 21.5.3 int DbgConsole\_Printf ( const char \* formatString, ... )

Call this function to write a formatted output to the standard output stream.

**Parameters** 

| formatString | Format control string. |
|--------------|------------------------|
|--------------|------------------------|

#### Returns

Returns the number of characters printed or a negative value if an error occurs.

## 21.5.4 int DbgConsole\_Putchar ( int ch )

Call this function to write a character to stdout.

**Parameters** 

| ch | Character to be written. |
|----|--------------------------|

#### Returns

Returns the character written.

#### **Function Documentation**

## 21.5.5 int DbgConsole\_Scanf ( char \* formatString, ... )

Call this function to read formatted data from the standard input stream.

Note

Due the limitation in the BM OSA environment (CPU is blocked in the function, other tasks will not be scheduled), the function cannot be used when the DEBUG\_CONSOLE\_TRANSFER\_NON\_B-LOCKING is set in the BM OSA environment. And an error is returned when the function called in this case. The suggestion is that polling the non-blocking function DbgConsole\_TryGetchar to get the input char.

#### **Parameters**

| formatString | Format control string. |
|--------------|------------------------|
|--------------|------------------------|

#### Returns

Returns the number of fields successfully converted and assigned.

## 21.5.6 int DbgConsole\_Getchar ( void )

Call this function to read a character from standard input.

Note

Due the limitation in the BM OSA environment (CPU is blocked in the function, other tasks will not be scheduled), the function cannot be used when the DEBUG\_CONSOLE\_TRANSFER\_NON\_B-LOCKING is set in the BM OSA environment. And an error is returned when the function called in this case. The suggestion is that polling the non-blocking function DbgConsole\_TryGetchar to get the input char.

#### Returns

Returns the character read.

## 21.5.7 status\_t DbgConsole\_Flush ( void )

Call this function to wait the tx buffer empty. If interrupt transfer is using, make sure the global IRQ is enable before call this function This function should be called when 1, before enter power down mode 2, log is required to print to terminal immediately

#### Returns

Indicates whether wait idle was successful or not.

#### **MCUXpresso SDK API Reference Manual**

## 21.5.8 int StrFormatPrintf ( const char \* fmt, va\_list ap, char \* buf, printfCb cb )

Note

I/O is performed by calling given function pointer using following (\*func\_ptr)(c);

#### **Parameters**

| in | fmt | Format string for printf.      |
|----|-----|--------------------------------|
| in | ap  | Arguments to printf.           |
| in | buf | pointer to the buffer          |
|    | cb  | print callbck function pointer |

#### Returns

Number of characters to be print

## 21.5.9 int StrFormatScanf ( const char \* line\_ptr, char \* format, va\_list args\_ptr )

#### Parameters

| in | line_ptr | The input line of ASCII data.             |
|----|----------|-------------------------------------------|
| in | format   | Format first points to the format string. |
| in | args_ptr | The list of parameters.                   |

#### Returns

Number of input items converted and assigned.

#### Return values

| IO_EOF | When line_ptr is empty string "". |
|--------|-----------------------------------|
| _      | <u> </u>                          |

#### **Semihosting**

## 21.6 Semihosting

Semihosting is a mechanism for ARM targets to communicate input/output requests from application code to a host computer running a debugger. This mechanism can be used, for example, to enable functions in the C library, such as printf() and scanf(), to use the screen and keyboard of the host rather than having a screen and keyboard on the target system.

#### 21.6.1 Guide Semihosting for IAR

**NOTE:** After the setting both "printf" and "scanf" are available for debugging, if you want use PRINTF with semihosting, please make sure the SDK\_DEBUGCONSOLE is disabled.

#### Step 1: Setting up the environment

- 1. To set debugger options, choose Project>Options. In the Debugger category, click the Setup tab.
- 2. Select Run to main and click OK. This ensures that the debug session starts by running the main function.
- 3. The project is now ready to be built.

#### Step 2: Building the project

- 1. Compile and link the project by choosing Project>Make or F7.
- 2. Alternatively, click the Make button on the tool bar. The Make command compiles and links those files that have been modified.

#### Step 3: Starting semihosting

- 1. Choose "Semihosting\_IAR" project -> "Options" -> "Debugger" -> "J-Link/J-Trace".
- 2. Choose tab "J-Link/J-Trace" -> "Connection" tab -> "SWD".
- 3. Choose tab "General Options" -> "Library Configurations", select Semihosted, select Via semihosting.
- 1. Make sure the SDK\_DEBUGCONSOLE\_UART is not defined, remove the default definition in fsl\_debug\_console.h.
- 1. Start the project by choosing Project>Download and Debug.
- 2. Choose View>Terminal I/O to display the output from the I/O operations.

## 21.6.2 Guide Semihosting for Keil µVision

**NOTE:** Semihosting is not support by MDK-ARM, use the retargeting functionality of MDK-ARM instead.

## 21.6.3 Guide Semihosting for MCUXpresso IDE

#### Step 1: Setting up the environment

- 1. To set debugger options, choose Project>Properties. select the setting category.
- 2. Select Tool Settings, unfold MCU C Compile.
- 3. Select Preprocessor item.
- 4. Set SDK\_DEBUGCONSOLE=0, if set SDK\_DEBUGCONSOLE=1, the log will be redirect to the UART.

#### Step 2: Building the project

1. Compile and link the project.

#### Step 3: Starting semihosting

- 1. Download and debug the project.
- 2. When the project runs successfully, the result can be seen in the Console window.

Semihosting can also be selected through the "Quick settings" menu in the left bottom window, Quick settings->SDK Debug Console->Semihost console.

## 21.6.4 Guide Semihosting for ARMGCC

#### Step 1: Setting up the environment

- 1. Turn on "J-LINK GDB Server" -> Select suitable "Target device" -> "OK".
- 2. Turn on "PuTTY". Set up as follows.
  - "Host Name (or IP address)": localhost
  - "Port":2333
  - "Connection type" : Telet.
  - Click "Open".
- 3. Increase "Heap/Stack" for GCC to 0x2000:

#### Add to "CMakeLists.txt"

```
SET(CMAKE_EXE_LINKER_FLAGS_RELEASE "${CMAKE_EXE_LINKER_FLAGS_RELEASE}}--defsym=__stack_size__=0x2000")
```

```
SET(CMAKE_EXE_LINKER_FLAGS_DEBUG "${CMAKE_EXE_LINKER_FLAGS_DEBUG} -- defsym=__stack_size__=0x2000")
```

SET(CMAKE\_EXE\_LINKER\_FLAGS\_DEBUG "\${CMAKE\_EXE\_LINKER\_FLAGS\_DEBUG} -- defsym=\_\_heap\_size\_\_=0x2000")

SET(CMAKE\_EXE\_LINKER\_FLAGS\_RELEASE "\${CMAKE\_EXE\_LINKER\_FLAGS\_RELEASE}} --defsym=\_\_heap\_size\_\_=0x2000")

## MCUXpresso SDK API Reference Manual

#### **Semihosting**

#### Step 2: Building the project

1. Change "CMakeLists.txt":

**Change** "SET(CMAKE\_EXE\_LINKER\_FLAGS\_RELEASE "\${CMAKE\_EXE\_LINKER\_FLAGS\_RELEASE} -specs=nano.specs")"

to "SET(CMAKE\_EXE\_LINKER\_FLAGS\_RELEASE "\${CMAKE\_EXE\_LINKER\_FLAGS\_R-ELEASE} -specs=rdimon.specs")"

#### Replace paragraph

SET(CMAKE\_EXE\_LINKER\_FLAGS\_DEBUG "\${CMAKE\_EXE\_LINKER\_FLAGS\_DEBU-G}} -fno-common")

SET(CMAKE\_EXE\_LINKER\_FLAGS\_DEBUG "\${CMAKE\_EXE\_LINKER\_FLAGS\_DEBUGG}} -ffunction-sections")

SET(CMAKE\_EXE\_LINKER\_FLAGS\_DEBUG "\${CMAKE\_EXE\_LINKER\_FLAGS\_DEBUGG}} -fdata-sections")

SET(CMAKE\_EXE\_LINKER\_FLAGS\_DEBUG "\${CMAKE\_EXE\_LINKER\_FLAGS\_DEBU-

G} -ffreestanding")

SET(CMAKE\_EXE\_LINKER\_FLAGS\_DEBUG "\${CMAKE\_EXE\_LINKER\_FLAGS\_DEBUG}} -fno-builtin")

 $SET(CMAKE\_EXE\_LINKER\_FLAGS\_DEBUG \quad "\$\{CMAKE\_EXE\_LINKER\_FLAGS\_DEBU-G\} -mthumb")$ 

SET(CMAKE\_EXE\_LINKER\_FLAGS\_DEBUG "\${CMAKE\_EXE\_LINKER\_FLAGS\_DEBUG} -mapcs")

SET(CMAKE\_EXE\_LINKER\_FLAGS\_DEBUG "\${CMAKE\_EXE\_LINKER\_FLAGS\_DEBU-

G} -Xlinker")
SET(CMAKE\_EXE\_LINKER\_FLAGS\_DEBUG

"\${CMAKE\_EXE\_LINKER\_FLAGS\_DEBU-

G} --gc-sections")

SET(CMAKE\_EXE\_LINKER\_FLAGS\_DEBUG "\${CMAKE\_EXE\_LINKER\_FLAGS\_DEBU-G} -Xlinker")

SET(CMAKE\_EXE\_LINKER\_FLAGS\_DEBUG "\${CMAKE\_EXE\_LINKER\_FLAGS\_DEBUGG}} -static")

SET(CMAKE\_EXE\_LINKER\_FLAGS\_DEBUG "\${CMAKE\_EXE\_LINKER\_FLAGS\_DEBUG} -Xlinker")

 $SET(CMAKE\_EXE\_LINKER\_FLAGS\_DEBUG \quad "\$\{CMAKE\_EXE\_LINKER\_FLAGS\_DEBU-G\} -z")$ 

SET(CMAKE\_EXE\_LINKER\_FLAGS\_DEBUG "\${CMAKE\_EXE\_LINKER\_FLAGS\_DEBUGG}} -Xlinker")

 $SET(CMAKE\_EXE\_LINKER\_FLAGS\_DEBUG \quad "$\{CMAKE\_EXE\_LINKER\_FLAGS\_DEBU-G\} \ muldefs")$ 

#### To

SET(CMAKE\_EXE\_LINKER\_FLAGS\_DEBUG "\${CMAKE\_EXE\_LINKER\_FLAGS\_DEBUGG}} --specs=rdimon.specs")

#### Remove

target\_link\_libraries(semihosting\_ARMGCC.elf debug nosys)

2. Run "build\_debug.bat" to build project

337

## Step 3: Starting semihosting

(a) Download the image and set as follows.

```
cd D:\mcu-sdk-2.0-origin\boards\twrk64f120m\driver_examples\semihosting\armgcc\debug
d:
C:\PROGRA~2\GNUTOO~1\4BD65~1.920\bin\arm-none-eabi-gdb.exe
target remote localhost:2331
monitor reset
monitor semihosting enable
monitor semihosting thumbSWI 0xAB
monitor semihosting IOClient 1
monitor flash device = MK64FN1M0xxx12
load semihosting_ARMGCC.elf
monitor reg pc = (0x00000004)
monitor reg sp = (0x000000000)
continue
```

(b) After the setting, press "enter". The PuTTY window now shows the printf() output.

**SWO** 

#### 21.7 SWO

/\*!

Serial wire output is a mechanism for ARM targets to output signal from core through a single pin. Some IDE support SWO also, such IAR and KEIL, both input and output are supported, reference below for detail.

#### 21.7.1 Guide SWO for SDK

**NOTE:** After the setting both "printf" and "PRINTF" are available for debugging, JlinkSWOViewer can be used to capture the output log.

#### Step 1: Setting up the environment

- 1. Define DEBUG\_CONSOLE\_IO\_SWO in your project settings.
- 2. Prepare code, the port and baudrate can be decided by application, clkSrcFreq should be mcu core clock frequency:

```
DbgConsole_Init(port, baudrate, DEBUG_CONSOLE_DEVICE_TYPE_SWO, clkSrcFreq);
```

3. Use PRINTF or printf to print some thing in application.

#### Step 2: Building the project

## Step 3: Download and run project

#### 21.7.1.1 Guide SWO for IAR

**NOTE:** After the setting both "printf" and "scanf" are available for debugging.

#### Step 1: Setting up the environment

- 1. Choose project -> "Options" -> "Debugger" -> "J-Link/J-Trace".
- 2. Choose tab "J-Link/J-Trace" -> "Connection" tab -> "SWD".
- 3. Choose tab "General Options" -> "Library Configurations", select Semihosted, select Via SWO.
- 4. To configure the hardware's generation of trace data, click the SWO Configuration button available in the SWO Configuration dialog box. The value of the CPU clock option must reflect the frequency of the CPU clock speed at which the application executes. Note also that the settings you make are preserved between debug sessions. To decrease the amount of transmissions on the communication channel, you can disable the Timestamp option. Alternatively, set a lower rate for PC Sampling or use a higher SWO clock frequency.
- 5. Open the SWO Trace window from J-LINK, and click the Activate button to enable trace data collection.

6. There are three cases for this SDK\_DEBUGCONSOLE\_UART whether or not defined. a: if use uppercase PRINTF to output log, The SDK\_DEBUGCONSOLE\_UART defined or not defined will not effect debug function. b: if use lowercase printf to output log and defined SDK\_DEBUGCONSOLE\_UART to zero, then debug function ok. c: if use lowercase printf to output log and defined SDK\_DEBUGCONSOLE\_UART to one, then debug function ok.

**NOTE:** Case a or c only apply at example which enable swo function, the SDK\_DEBUGCONSOLE\_U-ART definition in fsl\_debug\_console.h. For case a and c, Do and not do the above third step will be not affect function.

1. Start the project by choosing Project>Download and Debug.

#### Step 2: Building the project

#### Step 3: Starting swo

- 1. Download and debug application.
- 2. Choose View -> Terminal I/O to display the output from the I/O operations.
- 3. Run application.

## 21.7.2 Guide SWO for Keil µVision

NOTE: After the setting both "printf" and "scanf" are available for debugging.

#### Step 1: Setting up the environment

There are three cases for this SDK\_DEBUGCONSOLE\_UART whether or not defined. a: if use
uppercase PRINTF to output log,the SDK\_DEBUGCONSOLE\_UART definition does not affect the
functionality and skip the second step directly. b: if use lowercase printf to output log and defined
SDK\_DEBUGCONSOLE\_UART to zero,then start the second step. c: if use lowercase printf to
output log and defined SDK\_DEBUGCONSOLE\_UART to one,then skip the second step directly.

**NOTE:** Case a or c only apply at example which enable swo function, the SDK\_DEBUGCONSOLE\_U-ART definition in fsl\_debug\_console.h.

- 1. In menu bar, click Management Run-Time Environment icon, select Compiler, unfold I/O, enable STDERR/STDIN/STDOUT and set the variant to ITM.
- 2. Open Project>Options for target or using Alt+F7 or click.
- 3. Select "Debug" tab, select "J-Link/J-Trace Cortex" and click "Setting button".
- 4. Select "Debug" tab and choose Port:SW, then select "Trace" tab, choose "Enable" and click O-K, please make sure the Core clock is set correctly, enable autodetect max SWO clk, enable ITM Stimulus Ports 0.

#### Step 3: Building the project

1. Compile and link the project by choosing Project>Build Target or using F7.

MCUXpresso SDK API Reference Manual

#### **SWO**

## Step 4: Run the project

- 1. Choose "Debug" on menu bar or Ctrl F5.
- 2. In menu bar, choose "Serial Window" and click to "Debug (printf) Viewer".
- 3. Run line by line to see result in Console Window.

## 21.7.3 Guide SWO for MCUXpresso IDE

**NOTE:** MCUX support SWO for LPC-Link2 debug probe only.

#### 21.7.4 Guide SWO for ARMGCC

**NOTE:** ARMGCC has no library support SWO.

How to Reach Us:

Home Page:

nxp.com

Web Support:

nxp.com/support

Information in this document is provided solely to enable system and software implementers to use NXP products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits based on the information in this document.

NXP makes no warranty, representation, or guarantee regarding the suitability of its products for any particular purpose, nor does NXP assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters that may be provided in NXP data sheets and/or specifications can and do vary in different applications, and actual performance may vary over time. All operating parameters, including "typicals," must be validated for each customer application by customer's technical experts. NXP does not convey any license under its patent rights nor the rights of others. NXP sells products pursuant to standard terms and conditions of sale, which can be found at the following address:

nxp.com/SalesTermsandConditions.

While NXP has implemented advanced security features, all products may be subject to unidentified vulnerabilities. Customers are responsible for the design and operation of their applications and products to reduce the effect of these vulnerabilities on customer's applications and products, and NXP accepts no liability for any vulnerability that is discovered. Customers should implement appropriate design and operating safeguards to minimize the risks associated with their applications and products.

NXP, the NXP logo, NXP SECURE CONNECTIONS FOR A SMARTER WORLD, Freescale, the Freescale logo, Kinetis, Processor Expert, and Tower are trademarks of NXP B.V. All other product or service names are the property of their respective owners. Arm, Cortex, Keil, Mbed, Mbed Enabled, and Vision are trademarks or registered trademarks of Arm Limited (or its subsidiaries) in the US and/or elsewhere. The related technology may be protected by any or all of patents, copyrights, designs and trade secrets. All rights reserved. Oracle and Java are registered trademarks of Oracle and/or its affiliates. The Power Architecture and Power.org word marks and the Power and Power.org logos and related marks are trademarks and service marks licensed by Power.org.

© 2018 NXP B.V.

